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WELCOME 
to The MagP1 77 


t’s incredibly important to make stuff. The Raspberry Pi computer, 
| and community, is — at its heart - all about the things you can 
make with this wonderful low-cost machine. 

Many makes are frivolous, like WhooPi cushions and Robotic 
Teapots; some are incredibly important, like monitoring the Borneo 
rainforest. Learning is important no matter what the outcome. 

This issue’s lead feature is Make with Code (page 26). In it you'll 
discover how to use the building blocks of electronics to build projects. 

The Raspberry Pican become just about anything with the right 
accessory: from screens, to robotic motor controllers, through to GPS 
and AI accelerators. Our guide to The Best Pi Accessories (page 68) is 
your dream toolbox. 

Every issue of The MagPi is packed full of inspirational projects. 

This month we’ve got an e-ink display work of art (page 22), a robot 
that takes selfies (page 16), a webpage testing machine (page 10) and 
even an automated bird caller (page 20). 

Build something fun. Something you love. Start with the fun stuff 
and you never know where it might 
end up. The Raspberry Pi has been 
used to save eyesight in India, and 
protect the coral reefs of Australia. 
But whether you build something 
world-changing or just mess around 
for fun, make sure you make stuff. 


Lucy Hattersley Editor 


LA PUN 
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Lucy 
Hattersley 


Editor of The MagPi. 
Lucy codes, crafts, 
and creates wonky 
robots. She speaks 
French (badly) and 
mangles the piano. 
One day she'll get 
that pet dog. 


magpi.cc 
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Bletchley Park 


National Museum of Computing holds STEM event for girls. Bravo, says Rosie Hattersley 


letchley Park played host to a hugely The female-focused STEM showcase was held at 
successful Girls’ STEM Day in late the National Museum of Computing, sited at the 
November, creating a real buzz among famous code-breakers’ venue with the express 
participants and demands for more events intention of highlighting the breadth of career 
of the kind. possibilities to students who may not otherwise have 
Among the sessions were Raspberry Pi been aware of their aptitude for such industries. It's 
workshops held in The National Museum of no secret that there's a significant imbalance in the 


numbers of males and females in STEM (science, 
technology, engineering, and maths)-based careers. 


It's no secret that there's a significant 
i ' Untapped potential 
imbalance in the numbers of males CybesecititivcSinmamveadbós wasan tle stout 


d for potential computer scientists of the future. 
an d fema | Es IN STE M VP Ali Kennedy noted that more than half the 


UK population is female and that “much more 


Computing’s (tnmoc.org) newly refurbished female involvement will be vital as we move into 
classroom. The MagPi writer Mark Vanstone the fourth industrial revolution.” Meanwhile, 
witnessed students getting stuck in to Python Buckinghamshire High Sheriff Professor Ruth 
coding and Raspberry Pi-based Minecraft. Farwell gave an inspirational talk in which she 


Students were challenged 
to complete tasks using 
Raspberry Pi computers 


06 magpi.cc Bletchley Park hosts Girls' STEM Day 


credited her own start on the road to a high-profile 
career to studying a STEM subject at university. 
While many of the 80-plus participants on the 
day already had an ongoing interest in science 
and technology, lots of attendees were delighted 
to unlock their previously undiscovered talents, 
and impressed observers with their teamwork 
and ingenuity. 
The RAF held a STEM Engineering Challenge, 
in which students had to master unfamiliar 
equipment and work in teams in order to complete 
tasks. Challenge organiser Chris Mossman came 
away seriously impressed with the students’ 
aptitude for logical thinking and problem-solving. 
PJ Evans, a TNMOC volunteer and The MagPi 
contributor commented, “More than 80 young 
women walked into The National Museum of 
Computing. I am certain more than one scientist, 
engineer, and programmer walked out. We saw 
eyes light up as the realisation dawned upon these 
young women that technology is as much for them 
and within their grasp as it is for anyone else." 


Career opportunities 

Peter Membrey, a software engineer who 
sponsored the event, said, *I work with many 
problem-solvers on a daily basis, but sadly there 


A The Girls’ STEM event 
was held at the National 
Museum of Computing, 
sited at the famous 
code-breakers' building 


The RAF held a STEM 
Engineering Challenge with Ex 
students working in teams y 


aren't many females among them. I think lots 
of girls miss out on these career opportunities 
because currently they are seldom helped to 
discover that they might have a natural gift 
for solving problems - which is, after all, what 
engineering is at its core." 

Event organiser Jacqui Garrad is already working 
on two events for 2019: one exclusively for girls, 
and another which will encourage teamwork 
among mixed teams of girls and boys. El 
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crowdsourced 
weather data 


People with Pi boards are using the PM2,5 Open Data Portal 
software to share weather and air pollution data in Taiwan 


e like to see citizen science here at The 
W MagPi - you may remember Raspberry 
Shake, the seismometer add-on for 
the Pi, which crowdsourced seismic activity. In 
East Asia, we hear a fair bit about issues with air 
quality, so we weren't too surprised when Nai-Wen, 
organiser of the Taiwanese Raspberry Pi community, 
told us about a project using open-source software 
to keep track of air pollution in Taiwan. 

“PM2.5 is a citizen science project. We provide 
instructions and open-source code to help people 
create and customise their own PiM25 box." 
Nai-Wen tells us via email. “When the PiM25 box 
is ready, air quality and GPS data can upload to the 
Taiwan's PM2.5 Open Data Portal (Location Aware 
Sensing System, or LASS) 24/7. Everyone can see 
the open data from the map (magpi.cc/rdfiGe)." 


Mapping the air 

The visualisation is fairly straightforward, 
colour-coding the results. Taipei, the capital, is 
fairly clean, but the west coast tends to be a little 
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polluted. Data is updated on the fly, so these values 
may change depending on wind, time of day, and 
even time of year. 

“We wanted to build up an easy-to-use airbox 
and visualise the environment information," 
Nai-Wen explains. *We hope the awareness will 
increase their interest in improving their air, 
health, life, and planet." 


Raspberry Pi in Taiwan 

While it's sometimes easy to think of the 
Raspberry Pi community as being largely UK based, 
it's important to remember that people use it all 
around the world, including in Taiwan. 

Starting in 2013, there have been regular 
meet-ups every month or two, organised by 
Nai-Wen: *We have workshops, hackathons, and 
an occasional book club event. The community also 
helps to organise open-source conferences, such 
as PyCon Taiwan or MakerConf Taiwan.” 

We look forward to seeing what else comes 
out of the Taiwanese Pi community! El 


A There's not a huge amount 
of hardware needed for the 
PiM25 boxes 


Z Due to the live data 
update, the map may not 
always look this way 
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WebPageTest 


Testing your website on different browsers? You may be using a Raspberry Pi 
server farm you never knew existed. Rob Zwetsloot uncovers the details 


ne of the most invaluable tools to a web Patrick began using a similar setup while he 
Q developer is the ability to quickly test your was at Google working on web performance. Since 
| current build on a variety of browsers. Chrome, then, he’s built it up and deployed it under the 
Firefox, Safari, Internet Explorer (unfortunately), WebPageTest website, and the Raspberry Pi was 
and even mobile browsers need to be tested for. the only option for it. 
Fortunately, there are a lot of online services that 
Patrick can test it for you. One of these is WebPageTest Perfect with Pi 
Meenan (webpagetest.org), which just so happens to use “There are a ton of things that make them perfect 
a lot of Raspberry Pi boards. for my use case,” Patrick explains. “They are 
A software engineer “I largely use the Raspberry Pis as POE-powered inexpensive enough that I can use a dedicated 
Aei hen computers to control smartphones for testing mobile ^ Raspberry Pi for each phone or tablet in the lab. 
performance. He web performance," its creator Patrick Meenan tells “They provide enough power over their USB 
uses Pi boards in a us. “The public instance of WebPageTest has upwards port to both power and control most devices. They 
lot of his testing. of 80 Raspberry Pis driving the mobile testing for all can be powered over PoE, which gives me a way to 
webpagetest.org of the Android and iOS devices." remotely hard-reboot a device if needed (used to 


be a regular issue, but it has been months since 

I have had to reboot a device).” 
He continues, *The hardware watchdog 

integrated with my software nicely so the device 


A Websites are tested on 
various phones attached 
to Raspberry Pi boards 
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Various Android phones, 4 

iPhones, and tablets are = mcr Even though it uses shelves 

used in testing from a hardware store, it's 
definitely a server rack 


It only took a few 
hours to put the 
initial version 
together 


The software has 
been continually 
evolving over 

Six years 


The server has 
been running for 
nearly five years 
continuously 


Since it uses so many Raspberry 
Pi boards, some decent power 
solutions are needed 


There are 24 
Motorola G4s, 

the most popular 
phone in the setup 


Patrick uses a 
different PoE 
adapter from the 
official one 
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W The rows upon rows of phones 
are organised in a specific way 


self-reboots automatically if anything goes 
catastrophically wrong. 

“The software and community support are 
unmatched. I tried other (faster) SBCs, but they 
all had issues with missing packages or lack of 
community support.” 


m WebPageTest has upwards of 80 
Raspberry Pis driving the mobile 
testing for Android and iOS devices Ø 


Simple and sturdy 

It's a very simple setup beyond the software as well, 
merely using a PoE HAT on a Pi 3B* with 3D- printed 
cases. AII the individual phones are hooked up to 
the Pi so they can perform their testing duties. 
“They work amazingly well,” Patrick says. 

“It has gotten to the point where the mobile device 
testing is as stable as the desktop testing (which 
runs in VMs [virtual machines]). These days the 
mobile devices are set-and-forget. The software 
deployment is now fully scripted and I have a base 
image that I can clone to new SD cards and have a 
new device up and running in a few minutes." 

For the moment, Patrick's little Pi farm 

is holding up well, and is only occasionally 
maintained via the addition of more powerful 
models of Raspberry Pi when they become 
available. He hasn't even lost an SD card so far 
-atrue testament to the Raspberry Pi, SD cards, 
and Patrick's smart coding. El 


W The PoE HAT hadn't 
been released 
when he started, so 
the system uses a 

different solution 


A Tablets don't quite fit 
as well in the cases 
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Build a tester 


Not many cases you can buy are designed 
for connecting a Pi and a phone together 

- in fact, we'd venture a guess there are none. 
Patrick 3D-prints his own custom cases that make 
organising his server a bit easier. 


Patrick always uses the most powerful version 
of the Pi, as a lot of screen recording occurs in 
the process and a more powerful CPU is better for 
that. Here's a Raspberry Pi 3 strapped to the back of 
the custom case for just that purpose. 


03 The selected phone is powered and controlled 

by the Pi. The PoE HAT then powers the entire 
thing, and allows the Pi to connect to the network and 
do all the testing it needs to do. 


A The phone screens 
are recorded as 
part of the tests 
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Solar 
Inverter 
Monitor 


What do you do when it's tricky to get data from 
your solar power setup? Hack it with a Raspberry Pi 
of course, as Rob Zwetsloot finds out 


Clive 
Maynard 


A retired software 
engineer and 
computing lecturer 
who has made 
many contributions 
to education. 


clivemaynard.org 


> Are the national 
predictions accurate? 
Sort of 


interested in here on The MagPi - and not just 
because of the ways you can use it to power 
your outdoor Pi projects, even if that is very cool. So 


R enewable energy is something we’re pretty 


when Clive Maynard contacted us to share his project 


about keeping an eye on the performance of solar 
power inverters, we were all ears. 

“Tt starts with establishing communications with 
the inverter and then goes on to logging the data 
retrieved,” Clive tells us. “This involves the creation 
of CRC16 calculations to determine the validity of 
the data. Having logged the data, there is a need 

to display it for easy human understanding. The 


output of the solar inverter over a day of generation, 
and the second is a bar chart summary of the daily 
performance plotted over a month period.” 


lll. NREL Predicted kWh/day 


Ill 2015 kWh per day 


project involves two types of plot: the first traces the 


E 2016 kWh per day 


Solar inverters take the photovoltaic (PV) output 
from a solar panel and convert it to a more usable 
AC current. Why did Clive feel the need to build 
this system, though? Well, his solar inverter didn't 
make it easy to read its data. 


A simple solution 

“T have had a PV system at my home since 2015 and 
have kept records of its performance compared with 
the National Renewable Energy Laboratory (NREL) 
predictions for my location since getting it, every 
month scrolling through the menus on the inverter 
front panel to find the information I need and 
entering it into a spreadsheet. Interesting, but not 
as good as extracting the information from the solar 
inverter electronically." 

To read the data, all Clive needed to do was 
connect the RS-485 serial output to the Pi using a 
USB converter and then parse that output for the 
relevant information for his graphs. 

“Tt is a cheap, powerful system which has a good 
programming environment and operating system, 
together with relatively easy interfaces to collect the 
data,” explains Clive about his reasons for using a 
Raspberry Pi. “I have spent many years using UNIX, 
C, and Python, so [it was] an easy choice." 


Renewable graphing 

The results speak for themselves, with graphs 
aplenty for data lovers to look over. It's important 
to know how solar energy works if we're to rely on 
it more in the future. For now, Clive has a couple 
of things he'd like to improve with his setup: 
“Physically I should make a more secure mounting 
for the Raspberry Pi and interface in my garage. Ill 
also set the logging program up to automatically 
run on reboot, to allow for power failure and get the 
logging back on as soon as possible." li 


lll 2017 kWh for the day lll 2018 kWh for the day 
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4 


Not your standard serial 
output, Clive needed a USB 
converter to access it 


Ww 
E du 


Solar power needs to be 
converted from a variable 
DC output to usable AC 


Photovoltaic 
current exists as 
DC (direct current) 


You can use 
pvwatts.nrel.gov 
to see your home's 
projected output 


Solar panels are 
a lot cheaper 
and affordable 
these days 


Clive has been 
programming 
since 1965 


While the output is 
in C, a lot of the Pi 
code is in Python 


Data can be read directly 
on the box, but it takes a 
bit of digging 


* BAS. heb * 
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SelfieBot 


Want to snap a selfie and put a smile on the face 
of the camera? David Crookes meets SelfieBot 


Sophy 
Wong 


Sophy is an 
accomplished 
maker as well as a 
designer of fashion, 
jewellery, costumes, 
and wearable 
technology. She 
has a strong 
background in 
graphic systems 
and marketing. 


magpi.cc/hhoBck 


fter Sophy Wong's SelfieBot wakes from a 
A snooze, it makes a cute noise, sings a song, 

winks at a passer-by, and then blinks silently. 
Or at least, it does if it’s left alone for long enough: 
its ability to capture fun photos and print them on to 
thermal paper ensures it’s nearly always in demand. 

SelfieBot sprung into life in 2017 when Sophy and 
her husband Kim Pimmel created an early version 
for their local Seattle Mini Maker Faire. “We thought 
that if we created a fun selfie-taking experience, with 
something visitors could take home like a printed 
photo, it would encourage people to the booth and 
give them another way to interact with our projects.” 

The plan worked a treat. SelfieBot - mains-powered 
and made from laminated laser-cut plywood - went 
down a storm, so the couple decided to refine the 
concept for 2018. Rather than have it tethered to one 
location, they opted for a mobile version. 

“T redesigned the circuit so that it could be powered 
by a small 7.2 V NiMH battery like the ones in radio- 
controlled cars,” Sophy explains. The idea of putting 
a Raspberry Pi 2 at its heart remained, however. 

The Pi is connected to a Pi Cobbler which routes 
all of the Pi’s GPIO pins to a Perma- Proto board. A Pi 


A When the accelerometer detects 
it has been placed on its back, 
the SelfieBot falls asleep and 
shows a snoring animation 
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A Sophy wanted the SelfieBot to look and 
feel real and manufactured, rather than 
home-made, hence the polished, clean 
housing and tidy interior 


Camera Module V2 is used to take photos, while 
a mini metal speaker is hooked up to an Adafruit 
mono 2.5W class D audio amplifier, to allow the 
SelfieBot's sounds and jokes to be clearly heard. 
For its face, which beams bright from a 5-inch 
HDMI display, the couple conducted a lot of 
research. “We analysed the features of cute 
robots and scary robots, knowing that we wanted 
a face and sounds that were appealing, cute, and 
non-threatening,” Sophy says. 


m We hardly print anything 
these days, especially 
photos, so it's a lot of fun Ø 


Kim created the code for this, producing 
animated faces - made up of individual images 
played in sequence. *When paired with sounds, 
which are recordings of my voice, the illusion is 
complete. We used the Pygame engine to drive 
the graphics and sounds, and CUPS for printing." 


And action 
Photos are outputted to a portable thermal printer. 
“It’s very satisfying to watch the image print 
before your very eyes,” Sophy says. “It seems like 
we hardly print anything these days, especially 
photos, so it's actually a lot of fun for people 
playing with SelfieBot.” 

She says folks love tearing off and keeping 
their photo, leaving with as big a smile as that 
on SelfieBot itself: “When a photo is printing, 
SelfieBot makes a cute face which is intended 
as a second reward... It feels like a big win." m 
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As well as displaying facial 
expressions, SelfieBot lets 
you preview your photo 


Pressing the arcade button 
(with LED) triggers the selfie 
mode, turning the camera on 


» The case is 
made from three 
acrylic panels 


Wall sections 
and handles 
are 3D-printed 


v 


SelfieBot does an 
impression of a dot 
matrix printer 


v 


v 


It takes 15 seconds 


Press the button again and the selfie 
to print a photo 


is taken, accompanied by a camera 
shutter sound. It then prints 


v 


Sophy toyed with 
*À| adding Twitter 
R Aa CN A. | to SelfieBot 


EIN 
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OpenSesamessage 


With a simple text message, you can open Conor Breen's door. 
As long as you're an the guest list. Rob Zwetsloot takes a look 


Conor 
Breen 


A computer 
Science graduate 
who specialises 

in loT and web 
development. He 
enjoys playing 
around with a 
Raspberry Pi in his 
spare time. 


magpi.cc/fzzAZL 


ahead, new solutions to old problems 

sometimes present themselves. Whilea 
trusty key may not be quite the thing of the past yet, 
electronic locks using RFID and other kinds of digital 
authentication are already occupying that space 
nicely. This is where OpenSesamessage comes in. 

“My project is a smart home entry system designed 
to be modular, cheap, and cross- platform," creator 
Conor Breen tells us. *It allows a person to add this 
device to their front door and, through the website, 
grant people access to the device through their 
phone number." 

While this is a little more involved than using a 
phone's built-in NFC capability, it probably makes it 
a little more secure in the process. In fact, the system 
makes use of Telegram, an open-source messaging 
service well known for its security. 


A s technology and interconnectivity steam 


Hidden origins 

“The idea stemmed from me always forgetting my 
keys," Conor admits. “But, because of forgetting my 
keys, I would invariably have my phone to call someone 
to either let me in or lend me theirs. So why not cut out 
the middleman and [let] my door be the one I text? 

“Tt worked better than expected. The device 

was able to parse incoming messages; even when 
bombarded, it would just queue them. Users would 


Gi Users would be returned messages either 
allowing them entry or disallowing them @ 


be returned messages either allowing them entry or 
disallowing them. I was approached by people who 
were thinking up new use cases for this device; one 
in particular was a person who had a few Airbnb 
apartments, and they thought this would be a great 
alternative to a key box outside the apartment." 


Practical applications 

While the project was tested on a model door, Conor 
assures us it would work just fine on a normal one - 
the latch lock in particular was one that you would 


18 | magpicc | OpenSesamessage 


A Conor built a small 
door for his project, 
although it uses a 
full-size lock 


A This interface is used to add 
numbers and manage the 
overall system 


use on a regular door anyway. Even then, there are 
some ways in which he'd like to improve it. 

“I am interested in adding extra functionality, 
such as adding cron jobs to give a user privileges 
for a specified amount of time and when that 
time is up, their access would be revoked," Conor 
explains. “And if I had an untold amount of time, I 
would love to have gotten into writing a messenger 
service from the ground up, and have a bespoke 
app for the device. Hardware-wise, I would have 
updated the battery pack that operated the servo to 
be rechargeable, and maybe charged out of one of 
the USB ports.” 

You can read Conor’s complete paper, full of all 
the technical information you’d ever need on the 
project, here: magpi.cc/fzzAZL. {i 
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» It's built with Ruby 
on Rails 


» There's 64-bit 
encryption in 
the lock 


» Lua is used to 


. ; parse messages 
This test version of 


the device is currently 


» The GPIO pins 
battery-powered 


directly control 
the lock servo 


» This was Conors 
final-year university 
computing project 


The latch is controlled 
by a servo connected to 
the Raspberry Pi 


The Raspberry Pi runs the 
service OpenSesamessage, 
which checks users for access 
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Martha lives on 

her ranch in rural 
Nevada after more 
than three decades 
in Silicon Valley as a 
software engineer/ 
architect. She now 
trains gun-dogs and 
watches over her 
herd of equine. 


manray.com 


Game Bird Recall 


Managing wildlife populations by mimicking their calls is another 
job for the Raspberry Pi. Phil King heeds the call of the wild 


birds to train her gun-dogs, Martha Zimet 
has developed a Raspberry Pi-based system 
to mimic the birds’ rallying calls in order to ‘anchor’ 
them to a geographic area (magpi.cc/nHzNWA). 
*In my experience, game birds really train gun- 
dogs,” Martha advises. “They teach the dogs to be 
stealthy, not jump in on the bird, manage their own 


H equiring an active population of wild game 


energy, otherwise, the dog never gets what it desires: 


the bird in its mouth. Therefore, to train your gun- 
dogs, what is required is ‘wild acting’ game birds.” 
Upon introducing a population of Coturnix 
(common) quail to her 80-acre Nevada ranch, she 
developed her own bird recall system to lure them to 
a specific location. “I do this by providing predator- 


A solar panel supplies power to 
the device and backup battery 
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proof food and water, and a ‘rally call’ for the 
specific species that effectively calls them back to 
the location where the food and water are located," 
she explains. “The released game birds become feral 
in about a month and act like wild game birds." 


Caught on camera 

Given the system's remote location, low energy 
consumption is a key factor. A solar panel hooked 
up to a backup battery provides the electricity, while 
a Witty Pi 2 board handles power management. 

“{It] has a real-time clock based on NTP, and it runs 
24/7,” says Martha. “It has programmed events, 
which execute only during daylight hours, that play 
the recorded game bird call at specific intervals. 


Recorded bird calls are played 
through a power horn speaker 


A Witty Pi 2 power 
management board wakes 
the Pi at specific times 


Images courtesy of Martha Zimet, CC BY-NC-SA 3.0 


A Awaterproof case 
keeps the electronic 
components safe in 


> It can play up to six 
recorded calls 


» These are selected 
via capacitive 
touch buttons 


» Extra environmental 
Sensors can 
be added 


> A Pi NoIR camera 
is triggered by 
motion detection 


A Once installed out in the field, the 
system is self-sufficient, minimising 
human intervention that might 
affect the wildness of the birds 


» Images are 
transmitted via 
a 3G network 


any weather conditions 
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During these events, the [Pi NoIR] camera is also 
active and can record any movement detected and 
transmit the results to me." 

For the latter, Martha is using the Soracom 
cellular IoT network. “Since I am not transmitting 
live video from the devices, I can simply use 3G 
connectivity. It has proven to be very reliable. 


m They can be used for any 
wild game population, 
and not just game birds @ 


I use an external antenna to the GSM modem, and 
everything is enclosed in a waterproof case. I spent 
well over a month attempting to use WiFi, and even 
with clear line of sight to my location, high power 
Yagi antennas were just too wonky.” 


Stickler for quality 
The whole system took Martha about six months 
to develop. *A major portion of the time was spent 
validating components, where the most challenging 
ones were solar power, batteries, and connectivity. 
Since the units are installed at remote locations, 
they just have to work. Given my background, I am 
a stickler for quality. The [Python] software I wrote 
— my ‘secret sauce’ - was small in comparison to 
the validation process.” 
With a US patent pending, Martha is offering 
a commercial service to install similar devices in 
other locations. “Each system I develop is based on 
user requirements and use cases. So far, there is no 
way to mass-produce them, but they can be used for 
any wild game population, and not just game birds.” 
Martha has been invited to the Yukon next 
autumn, to evaluate the system for use with the 
wild moose population. In addition, she reveals: 
“I have connections in Finland and I have hopes the 
system could be used by the Sami population with 
their reindeer herds.” El 


Game Bird Recall | magpicc | 21 


ME Magri | PROJECT SHOWCASE 


E-ink Display 


Project 


Green in more than one sense, the E-ink Display Project 
is both a useful tool and a rather fetching piece of art. 
Nicola King admires this ingenious piece of creativity 


Anke 
Dietzen 


An enthusiastic 
maker in her 


precious spare time, 


Germany-based 
Anke Dietzen loves 
to learn, tinker, 
and create. 


ankesreich.de 


id you know that e-ink displays can retain what 
D they’re showing, even without electricity? By 
anyone’s standards, that makes them pretty 
ecological. The E-ink Display Project, developed by 
Anke Dietzen, is a resourceful and inventive take on 
a very cool way of displaying information. 
The project’s origins came through reading an 
article about the Raspberry Pi, as Anke explains: 
“I thought ‘how cool is that’, and I wanted to do 
something with the Raspberry Pi. I ordered [one] 
and, very enthusiastically, a big sensor kit. As I had 
no knowledge of electrical engineering, I had to learn 
some basics and I was very happy then to light a diode 
on a breadboard.” 
At the same time, Anke bought a small Waveshare 
e-ink display, which she favoured for its very clear and 
precise visuals. Armed with her new purchases, she 
set about coming up with a practical display that would 
also look good. *I wanted to do something with e-ink 


mı had no knowledge of electrical engineering 
- | had to learn some basics, and was very 
happy to light a diode on a breadboard Ej 


displays which I thought should be at least a little 
useful," she tells us. *As, in the morning, I normally 
check the weather via smartphone, I thought it would 
be nice to read the latest weather information and 
calendar entries / birthdays with just one look." 


Picture perfect 

As well as including informative data such as forecasts 
and reminders, Anke wanted the possibility of having 
images on the screen, so, “I used a bigger three- 
colour display (7.5-inch - 640x384 pixels) for showing 
pictures. The picture shown was always taken in 
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A From a webpage. 
Anke can add 

pictures, birthdays/ 

events, and messages 


Anke gave the display an 

organic look using artificial moss 

aS i a a Sk 
27979. AC IY 


, 
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the same month of the actual date, in the style 

of ‘do you know what happened X years ago at 

this time?” she says. In addition, she describes 
the key benefit of using an e-ink display: “If you 
disconnect [it] from power, the Raspberry Pi will 
keep the last picture forever, unlike the ‘normal’ 
displays which need power to show something. The 
power consumption is very low in standby mode.” 


Ink...redible 

So, how does it work? Anke reveals, “The 
Raspberry Pi controls two e-ink displays. On 

the Pi, all the time an application server with 

a database is running. Over a webpage (REST 
interface), the actions can be triggered: actions 
are, for example, ‘store message in database’, 
‘fetch weather information from internet and 
store in database’, ‘store picture info in database’, 
‘refresh display from database’, etc. For displaying 
a picture, or the weather information, the 


MägPi 


A smaller display shows 
the weather forecast 
and important reminders 


The displays 
are controlled 
by a single Pi 
on the rear 


It's housed in 
i SCO an IKEA Ribba 


The larger e-ink display is used picture frame 


to show pictures and messages 


The display can 
be controlled via 
a webpage 
application creates a temporary monochrome 
bitmap which is then shown.” Custom 
Being familiar with Java, it was natural for Anke @ So 21.10.2018: messages can 
to use it to code the project. “I first had to transfer Tuin a be entered 


the Python driver logic provided by the e-ink 
display producer to Java.” She then spent some 
time figuring out how to get the Raspberry Pi to 
control two e-ink displays at the same time. 
Aesthetically, the finished project is calming 
to the eye. Anke used some artificial moss to give 
it a very organic feel and, with it hanging in the Eur 
IL a Very orB ] ging Mo 29.10.2018: Cafe 
kitchen of her home, the feedback that she has 15 Uhr : 
received from other members of the household 
has been, unsurprisingly, very positive. 
Charming, functional, and eco-friendly, it makes 
a refreshing change from the more mundane Te Sater di pray Show: 
. : useful information including 
pinboard or sticky note! a weather forecast and events 


(9 Di 23.10.2018: 
E.abend The larger 
display can also 


© Do 25.10.2018: 8.20 show yellow 


Uhr impfen 


© So 28.10.2018: 
Geburtstagsfeier 
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Qu 


ought a Raspberry Pi to learn how to code 
gizmos, then you have made 


arted with this guide... 


If you have b 
and hack new electronic 
a great choice. Get st 


f you have just got a brand new 
shiny Raspberry Pi, you may have 
plugged it in and got it working. 


You may have played a few of the games 


or tried out the applications, or maybe 
you’ve loaded one of the programming 
tools and then looked at it wondering 
what to do next. If you haven’t done 
any programming before, we have 
wisdom for you here. In the next few 
pages you'll find answers and probably 
some questions, but then some more 
answers. Before you know it you will be 
a coding, hacking ninja. 


H you have never dove 
any programming before, this 
may appear a bit daunting, 
bul it's quite easy really 


If you’re new to programming, this 
may appear a bit daunting, but it’s 
quite easy really - you've just got to 
get stuck in and start with some simple 
things that will get you results. One 
of the programming languages that 
is supplied with the Raspberry Pi is 
Python. It's very easy to get started 
with Python and it can be used to 
program many of the add-ons that are 
available for the Raspberry Pi - so this 
is going to be very useful to learn. We 
can get you up and coding in 30 seconds 
flat; just read on... 


` 


en 
» 


To get started with coding is really easy. Coding 
is just giving the Raspberry Pi an instruction to do 
something. The only thing you need to know is 
what language to talk to it in. In this case we are 
going to talk in Python 3. We will need to write 
our instructions somewhere so, to start, open a 
Terminal window - click the icon in the top left 
of the screen which is a grey box with a blue bar 
across the top. This opens a black window with a 
prompt: pi@raspberrypi:~ $ in green. If you type 
python3 and hit ENTER, Python starts and you 
will see the triple chevron prompt: »»». Now type 
print("Hello") and hit ENTER. Bosh! Your first 
program. You have instructed your Raspberry 

Pi to print the word 'Hello' and, all being well, 

it has obeyed. 

Entering programs like this is not going to be 
very useful most of the time, so now let's look at 
an app we can write and save a program with. 
Go to the desktop menu (click the Raspberry 
Pi logo in the top left of the screen) and in the 
Programming section, select Thonny (which 
should then open by default in its Simple mode). 
Try typing in the following program in the 
Thonny editor and save it, then run it by clicking 
the Run button. The output will be displayed in 
the Shell frame below the program editor. 


. import random 


. correct - False 
rn random. 

s [2] 

. while correct == False: 


(1,10) 


Magri 


5 


Mark 


Vanstone 


mwc1.py 


n ("Guess my number between 1 and 10: ") 


c C*1 
if (n) == r: 
correct - True 
else: 
if (n) » r: 


("Sorry, my number is lower. Try again.") 


else: 


("Sorry, my number is higher. Try again") 


("Well done. The correct answer was 
+ (c) + " tries.") 


You got it in 
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* (r) +". 


magpi.cc 27 


Coding involves using several el 


a look al a range of them and how they work 


Want to learn more 
about coding? Check 
out our guides to 
Python coding and 
object-orientated 
programming in 

The MagPi #53 and 
#54 respectively. 
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keyboard and output text and numbers by 

using the print() function. We have also used 
a condition structure in the form of if and else. 
Python is very particular about how you indent the 
code with spaces (four per indent level); this shows 
that the indented code is inside another structure. 
In the last program, everything indented after the 
while statement will be part of that loop. Let's take 
a look at a few more coding techniques. 


i n the last program, we get input from the 


ements. let's take 


Import modules 


Make new 


answer string 
Define data 


While not finished, 
input new guess 


Player wins Player loses 


A After initialising the data the program 
needs, we loop round, updating the 
answer variable until the player guesses 
all the letters or they run out of tries 


theWord. When we call a function that is inside 

a module, we use a full stop between the module 
name and the function name. Next, we want to get 
the player to start guessing what the word is. If we 
look at the bottom of the code, we can see that we 
call a function called startGuessing(). This is our 
own function that we need to define. 


01 Using lists 
We are going to write a Hangman-style 


game, where we start with a secret word and the 
player has to guess it, letter by letter. If correct, we 
show them where that letter appears in the word. 
They are allowed ten wrong attempts before the 
game ends. See the mwc2.py code to follow along. 
First, we make a list of words to choose from. A 
list is defined in Python using square brackets, 
like: list = ["a","b","c"]. We’ll call our list 
WORDLIST. In this case we’re writing the list name 
in upper case to show that it is a constant, i.e. It is 
not going to change throughout the program. 


Pick a word 

We can pick a word from our list using the 
random module. We import the module at the top 
of our code, then we can use the random. choice() 
function to get a word and store it in a variable: 
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DE Defining functions 

Each time we call a function, the code inside 
it runs. Sometimes functions have outputs, like our 
function updateAnswer() that returns the variable 
result. One of the rules of Python is that you must 
define a function before you call it, so we will need 
to define our startGuessing() function near the 
top of the code. To do so, we write def and then the 
name of the function, followed by brackets and a 
colon. If we want to pass variables as inputs into a 
function, we can add them inside the brackets. 


04 Getting loopy 


Now for the code in our startGuessing() 
function. We set the number of tries and dashes, 
one for each letter of the secret word, then we go 
into a loop. The code says: “While the player still 
has some tries left and the answer we have is not 
the secret word, run the following code.” In our 
loop, we print the answer we have so far and how 


random 


003. WORDLIST = [ 
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imwe2.py 


3 3 3 3 

3 3 ] 
004. theWord = random.choice(WORDLIST) 
005. 
006. def Q: 
007. triesLeft 10 
008. answer len(theWord) 
009. 
010. triesLeft 1 answer theWord: 
011. print("An answer) 
012. print(str(triesLeft) ) 
013. guess = input( ) 
014. len(guess) 1: 
015. print( ) 
016. guess theWord: 
017. print( ) 
018. answer updateAnswer(theWord, answer, guess) 
019. : 
020. print( ) 
021. triesLeft 1 
022. 
023. triesLeft LE 
024. print( theWord) 
025. : 
026. print( theWord) 
027. 
028. def » y ): 
029. result 
030. i range(len(word)): 
031. word[i] guess: 
032. result - result - guess 
033. : 
034. result - result - ans[i] 
035. result 
036. 
037. print( ) 


038. startGuessing() 


many tries the player has left. Then we use an if, 
elif, else condition structure to respond to the 
player, depending on what they typed. 


05| Changing the answer 


If the player guesses a letter correctly, we 
call another function: updateAnswer(). This 
uses a for loop to add the correct letters into 
our answer variable, then return that string (a 
variable containing letters/characters rather than 
a numeric value). This then becomes the answer 
variable that we print at the start of each loop in the 
startGuessing() function. When the player has 


guessed all the right letters in our word or they have 
got it wrong ten times, the program will drop out of 
the loop to reach the final part of the function. 


Win or lose 

We have an if and else structure to print 
congratulations, or let the player know they've run 
out of tries. A few of the functions are used with 
variables: len() finds the length of a string, and 
str() converts a number variable into a string so 
it can be added to the start or the end of another 
string. After the function is complete, it returns to 
where it was called, which is the end of the program. 
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FEATURE 


Now we've got the hang of the coding, let's put 
it to work with some electronic components 


A breadboard 


Aresistor 


2 x male-to-female 
jumper wires 
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into our code and used functions from it. If we 

want to control electronics from code, there 
is a very useful module available called gpiozero. 
GPIO stands for ‘general-purpose input/output’ 
and the line of double pins on one side of the 
Raspberry Pi are called GPIO pins. For details about 
the labels of all the pins, see pinout.xyz. If we 
connect electrical components to these GPIO pins, 
we can use the gpiozero module to make things 
happen. When we import a module, there are often 
many different functions inside. We can also make 
new coding ‘objects’ with them. Objects are like 
variables but have their own set of functions and 
properties inside them that we can call or change, 
and we do that using the same dot notation (full 
stop) that we did with the random module. For 
more details on using coding objects (called object- 
oriented programming or OOP), see issue 54 of 
The MagPi: magpi.cc/54. 


| n the previous example, we imported a module 


The breadboard 


Breadboards come in various sizes, but 
they all work in the same way. If there are tracks 
marked red and black/blue (and/or * and -) on the 
long edges of the board, these are for power and are 
connected along the length - although sometimes 
divided into sections. The matrix of holes which 
make up the main part of the board are connected 
in lines the other way (vertically in the diagram). 
There is usually a break in the centre of the board 
so that the two sides are not connected. 


02 Light-emitting diode (LED) 
An LED is a bit like a bulb in that if you apply 
electricity to it in the right way, it lights up. An LED 
is also a diode, which means that the electricity 
needs to flow in the correct direction or it will not 
light. When connecting an LED to the Raspberry 


PO 


Pi, we need to add a resistor to the 
circuit, as most LEDs will burn out if 
we connect them directly to the main 
power output. In the example, we are 
using a 1kQ resistor, but it's fine to 
use another similar value. To light 

an LED using gpiozero, assemble 
the components as in the diagram, 
then write a Python program: start 
with from gpiozero import LED, 
then create an LED object with led = 
LED(17), and finally type led.on() 
to light the LED. 


Aresistor 

Resistors do what their name 
suggests: they resist the flow of 
electricity (current). Some components 
need to have a certain amount of current 
in order to operate correctly. Resistors 
enable us to set the current or voltage to 
a suitable level for the other components 
we are using. There are many different 
types of resistors, with different 
resistance values. The resistance value 
can be read from the pattern of coloured 
stripes on the resistor. You can also 
get variable resistors, which are known 
as potentiometers. 


Jumper wires 

We need to connect 
our components to the 
Raspberry Pi GPIO pins. 
For this we use jumper 
wires. The ones we will 
be using have a female 
connector at one end, 
to go on the GPIO pins, 
and a male connector 
to go in the holes of the 
breadboard. You can also 
get jumper wires with 
both male connectors or 
both female connectors, 
for different situations. 
They can be bought in 
strips all joined together, 
sometimes known as 


‘jumper jerky’. 


S 


it 


A 
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Potentiometer 
A potentiometer is a variable resistor. It 
usually has a turning spindle that changes the 


resistance from one value to another, quite often 
rom no resistance to full resistance (no electricity 


flowing). A potentiometer can provide us with 

a variable output voltage which we can measure 
with the GPIO, but there is a slight problem. The 
potentiometer provides an ‘analogue’ 

output (varies continuously 
between values) and the GPIO 
inputs are only digital, i.e. 

on or off. So we need another 
component: an analogue-to- 
digital converter (ADC). 


Analogue-to- 
digital converter 


ADC components come in various forms, but the 


one we have in this example is called an MCP3008. 


It’s an integrated circuit (IC), meaning that it’s a 
box with some circuitry inside it. We don’t need 
to know what is inside it - we just need to know 
what to connect to each of the legs of the IC. We 


will need to wire up several of the legs to GPIO pins 


and provide the IC with power; when we've done 
that, we can connect the potentiometer to the IC 
and then read values in 
showing the position 
of the potentiometer 
spindle using the 
gpiozero module. 
We'll cover the code 4 
in the next section. p 
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You can control the 
state of the LED using 
the gpiozero module 
in Python 


Electronies 


quide 
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Breadboard 


6 x male-to-female 
jumper wires & 
10 x male-to-male 


jumper wires 


2 x potentiometers 


MCP3008 
integrated circuit 


Now to put what We have tovered to the test: we will make a 
retro game and control it with our own homemade controllers 


n the previous page we talked about 
Oo potentiometers and analogue-to- 

digital converters, and this is where 
we get to use them. It’s a bit more complicated 
than lighting up an LED, but only a little. First, 
we are going to write a program which has two 
rectangular bats at each side of the screen that 
can be moved up and down by two players. A ball 
bounces backwards and forwards between the 
bats until one player misses the ball and the other 
player scores a point. That’s right, you guessed 
it, the game is Pong and we are going to create a 
controller for each player from a potentiometer 
and wire it into the Raspberry Pi. 


Super-fast game coding 

If you have been following other coding 
articles in recent issues of The MagPi, you will know 
that when writing a quick game on the Raspberry 
Pi, Pygame Zero is your friend. We can make the 
basics of the game code very quickly by importing 
the pgzrun module, which holds all the Pygame 
Zero code. We need to call pgzrun. go() at the end 
of our code, and that's our game window sorted. As 
with all Pygame Zero programs, we have a draw( ) 
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function to write the graphics to the window, and 
an update() function to update the game items 
between draw cycles. 


02| Running the code 


The listing mwc3.py provides all the code 
you need for the game to work. There is some code 
in the updatePaddles() function for the keyboard 
to control the paddles or bats, just in case you want 
to test it before making the proper controllers. We 
import several modules with this code. We have 
covered pgzrun, but we also need random so that 
the ball will move in a random direction each time 
it starts. In addition, we need gpiozero to deal 
with the input from the controllers, and we need 
the math module for calculating the direction of 
the ball. 


DE Wiring it all up 

One thing to bear in mind when connecting 
any electronics to a computer is that if the 

wires are connected in the wrong way, you may 
cause damage to the computer or the electronic 


components, so it’s always a good idea to power off 
your Raspberry Pi before connecting anything to 
the GPIO pins. Follow the wiring diagram (overleaf) 
carefully, making sure that the jumper wires are 
connected to the right GPIO pins and to the correct 
places on the breadboard. Once you have put 
everything in place, it’s a good idea to have another 
check just to make sure. 


The MCP3008 IC 


The MCP3008 converts the voltage from our 
potentiometers into a number with the help of the 
gpiozero module. It has eight channels for input, 
but we are going to just use two of them in this 


3008 -UPE 
> 18081UG 


case. You will see from the diagram that all t 


he legs 


on the top side of the IC are connected to either 


GPIO pins or to power lines. There are two red 


connections going to the positive power trac 


k, then 


a black lead to the negative or ground track. Then 
there are four coloured wires that go to: purple - 


GPIO 11; green - GPIOO09; orange - GPIO10; a 


nd 


blue - GPIOO8. Then there is one last connector to 


the ground track. 


The inputs 


All the MCP3008 pins on the bottom side 
of the IC are input channels. We will use the first 


two pins, which are channel o and channel 1. 


We 
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It may seem like a lot of 
wires, but work through 
the diagram methodically 
to make sure they are 
plugged in correctly 
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The MCP3008 
straddles 
the centre 
break of the 
breadboard so GPIO11 GPIOO9 GPIO10 
that the pins on ] 
either side are GPIOO8 eds wyqe Ex e 
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The left-hand 
potentiometer's 
middle pin 
connects to pin 
o, and the right 
one's to pin 1 of 
the MCP3008 


A When everything is 
plugged in and working, 
you can play Pong! 
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connect the middle pins of our potentiometers to 
those channel pins, which will read the positions 
and convert that to a value in our program. If you 
want to know exactly what all the pins are for on 
this IC, you can do a web search for ‘MCP3008 
pinout' and that will give you descriptions of each. 
ICs are very useful in electronics as they mean that 
we can reduce how complex our circuits are and we 
don't need to know exactly how they work inside. 
They are a little bit like modules in Python. 


Drj Finishing the job 

When you have checked that all the 
connections are correct, you can switch the 
Raspberry Pi back on and reload your program. You 
may want to initialise the SPI interface on your 
Raspberry Pi by going to the main desktop menu 

> Preferences > Raspberry Pi Configuration, and 

go to the Interfaces tab. It will work without this, 
but may cause a few warnings in the Thonny shell 
window. So, all being well, when you run your 
program you will have a game of Pong which can be 
controlled by two players with the potentiometers. 
If it doesn’t work first time, check your code and 
then your wiring, and try again. 


004. 
005. 
006. 
007. 
008. 
009. 
010. 
011. 
012. 
013. 
014. 
015. 
016. 
017. 
018. 
019. 
020. 
021. 
022. 


023. 


024. 
025. 
026. 
027. 
028. 
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03e. 
031. 
032. 
033. 
034. 


035. 
036. 
037. 
038. 
039. 
040. 
041. 
042. 
043. 
044. 
045. 
046. 
047. 
048. 
049. 


pgzrun 
random 

gpiozero 
math 


MCP3608 


poti - MCP3008(0) 
pot2 - MCP3008(1) 


# Set up the colours 


BLACK = (0 ,0 ,0 ) 
WHITE - (255,255,255) 
piScore p2Score = 0 
BALLSPEED 5 
p1Y = 300 
p2Y = 300 
def OQ: 
screen. fill(BLACK) 
screen.draw. line((490,0), (400,600), ) 
drawPaddles() 
drawBall() 
screen.draw.text(str(piScore) , (105, 
40), WHITE, 60) 
screen.draw.text(str(p2Score) , (705, 
40), WHITE, 60) 
def Q: 
updatePaddles() 
updateBall() 
def (): 
ballX, ballY, ballDirX, ballDirY 
ballX 400 
ballY 300 
a = random.randint(10, 350) 
(a > 80 a « 100) (a » 260 a 
280): 
a = random.randint(10, 350) 
ballDirX = math.cos(math.radians(a)) 
ballDirY - math.sin(math.radians(a)) 
def Q: 
piY, p2Y 
pirect = Rect((100, piY-30), (10, 60)) 
p2rect = Rect((700, p2Y-30), (10, 60)) 
screen.draw.filled_rect(pirect, ) 
screen.draw.filled_rect(p2rect, ) 
def Q: 


p1Y, p2Y 


p1Y = (poti.value * 540) +30 


052. 
053. 
054. 
055. 
056. 
057. 
058. 
059. 
060. 
061. 
062. 
063. 
064. 
065. 
066. 


067. 
068. 
069. 
070. 
071. 
072. 


073. 
074. 
075. 
076. 
077. 
078. 
079. 
080. 
081. 
082. 
083. 
084. 
085. 
086. 
087. 
088. 
089. 
090. 
091. 
092. 
093. 


094. 
095. 
096. 
097. 
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p2Y = ( 
pot2.value * 540) «30 


keyboard.up: 
p2Y > 30: 
p2Y 2 
keyboard.down: 
p2Y « 570: 
p2Y 2 
keyboard.w: 
p1Y > 30: 
p1Y 2 
keyboard.s: 
p1Y < 570: 


def Q: 
ballX, ballY, ballDirX, ballDirY, 
piScore, p2Score 


ballX bal1DirX*BALLSPEED 

bally bal1DirY*BALLSPEED 

ballRect = Rect((ballX-4,ballY-4),(8,8)) 
pirect = Rect((100, p1Y-30), (10, 60)) 
p2rect = Rect((700, p2Y-30), (10, 60)) 


checkCollide(ballRect, pirect) 
checkCollide(ballRect, p2rect): 

ballDirX 1 

ballY < 4 ballY > 596: 
ballDirY 1 

ballX < 0: 
p2Score 1 
init() 

ballX > 800: 
piScore 1 
init() 


def (r1,r2): 


) 
def Q: 
screen.draw.filled circle((ballX, ballY), 8, 
) 
init() 


pgzrun.go() 
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| You'll Need 


» P8X32A processor 
magpi.cc/pNdgpi 


» 24LC245 EEPROM 
magpi.cc/ctpjtt 


» 5MHz crystal 
magpi.cc/inNNCq 


» USB to TTL serial 
adapter 3.3 V 5.5V 
magpi.cc/ViLqJr 


» Full parts list 
magpi.cc/pptCFz 


P1 Bakery: 


[n a spin 


Enhance your Raspberry Pi by adding a VGA output and a retro 8-bit 
sound chip emulator using the eight-core Propeller chip 


Raspberry Pi, maybe for a two-player game 
or to log extra information? Then dust off 
that old VGA monitor and put it to good use to 
make a text and graphics display. Ever wanted 
to recreate those authentic 8-bit sounds of 
yesteryear without trying to buy long obsolete 
chips? Well now you can, easily and cheaply, 
by using the remarkable but much neglected 
Propeller chip. We will show you how to do it, as 
well as making a Propeller development board for 
even more projects. 


E ver wanted an extra display on your 
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The spin processor 

The Propeller spin processor has been 
around for some time now and, in many ways, 
it was ahead of its time. It has eight processors 
that are called ‘cogs’; they all operate in parallel 
and can run at speeds in excess of 96MHz. Each 
one has a turn at controlling the output pins, 
hence the name 'spin'. This is summarised in 
Figure 1. In addition to the cogs, there is memory: 
both RAM and ROM, which are shared resources 


System 
Counter 


for all the cogs. On bootup, code can be loaded 
automatically from an external EEPROM, so in 
effect the processor can run any code without 

specifically loading it. 


Spin language 

Built into the processor is an interpreter 
for a language called Spin, which has a simple 
syntax and is quite easy to learn. You can also run 
machine code, for those tasks that require it. Ina 
similar way to the Arduino, preprogrammed cog 
codes can easily be dropped in, just like libraries, 
and there is a cog exchange website where you can 
download over a hundred cogs. In effect, you can 
think of cogs as programmable peripherals, and 
that is what we want to do with them here. 


Our project 

What we are going to do is to builda 
development board for this processor and make 
a VDU display, and a retro sound chip emulator 
with it, and show you how to drive these new 
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RAM,ROM 
Configuration, 
Control 


A Figure 1 The spin 
processor's cogs 


Y Figure 2 The block 
diagram of our system 


3V3 & 5V power 


GPIO 
USB module 


Raspberry Pi USB 


Spin Board 


VGA Monitor 


Stereo output 
Active speaker 
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2 Spin Processor 8 
Boot up EEPROM L A/D Converter 
12C 3 - 2 bit converters VBA Socket 
2 
USB to 3V3 TTL — “~~ 2 : 
Eum L| Audio Filtering Audio sinck’socket overall structure of what we are going to make, 
DTR without delving into all the detail we need to 
add to make a schematic. Connections between 
id Test LED blocks that consist of more than one wire are 
— eet Figure 3 often shown, as here, bya thick ine with a slash 
and number above it, to indicate the number of 
wires involved. As well as the video and audio 
outputs, we have included an LED to flash, and 
A Figure 3 The block peripherals with Python. Figure 2 (previous page) there are 15 unused I/O pins on the processor for 
Sud our shows the block diagram of our project. With the further expansion. 
introduction of the Raspberry Pi 3, there has been 
a change to the serial port on the GPIO pins; so 
to allow our project to seamlessly work with any 
model, we have chosen the USB route to access it, The full schematic 
but taking its power from the Pi itself. Figure 4 shows the full schematic of the 
board. By reference to the block diagram, you 
can identify the main functional units. The three 
video components - R, G, and B - are made using 
Our board two pins, each joined together through resistors, 
Figure 3 shows the block diagram of the to form a simple DAC (digital-to-analogue 
board. A block diagram is useful for getting the converter). For best results, these resistors should 
ava 
AOR M Jar "Y Figure 4 The schematic Figure 4 
| | of our spin board 
35 (P26) 2 is 
ae 2 B 
SMHz 
Red LED = 7 71 
SN 
N 77 EN (P29) 38 BU de 2 
XO SCK 
31 (P28) 37 6 ; 
10 (BOEn) 24LC256 
LA 16uF 
Reset - P8X32A (DIP) | (P1) 16 Tk li 
(P10) 15 Audio output 
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E] E] E] w 1 
1 


be accurate to 1%. The audio circuits consist 

of a10kQ resistor and 10nF capacitor to form 

a restoration filter, which will remove a lot of 

the PWM noise. Then a capacitor provides AC 
coupling, and a final trim pot allows you to adjust 


the output. ii 
* Figure 5 The 
track side of 
Preparing the board PUESPIBBESIE 
The project is constructed on a piece of gi Y Figure 6 The 
, s 2 ] [ physical layout 
32-strip, 37-hole stripboard - see Figure 5. The d. -a of our spin board 


3V3 Gnd 5V 


5.00 MHz 


VGA SOCKET 


24 


USB Module 


30 


BC237BG 
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Pa 
“TR 


12mm 


A Figure 7 Fitting wire 
anchors to the USB module 


grey squares indicate where the track has been 
cut around a hole. Each hole has a coordinate, 
given by a strip and hole number; strip numbers 
go from top to bottom and, on the underside, hole 
numbers go from right to left. Drill four 3mm 
board mounting holes at S2 H36 (Strip 2 Hole 36), 
S2 H2, S31 H2, and S31 H36. Add the VGA socket 
mounting at S6 H34 and S19 H34, and fit the audio 
jack. Make all the cuts in the tracks. 


07 Building the board 

Figure 6 (previous page) shows the 
components - on this side, hole numbers go from 
left to right. The ‘hidden detail’ of the track breaks 
and the strip outlines can be seen through the 
board. Start by soldering the 40-pin socket with 


Y Figure 8 The VGA 
socket's bracket 


12mm 


16mm 


46mm 
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pin 1 at 53 H19. Then add a 0.1 pF capacitor at S11 
H21 and S11 H23, and another at S14 H21 and S14 
H23. As these will be inside the socket, push them 
flat against the board so they don't foul the chip. 
Next, add the 8-pin socket with pin 1 at S6 H3. 


Adding the components 

Now, add all the wire links; these are the 
vertical black lines. Then add all the resistors 
and the push-button. Next, add the LED - note 
the flat on the lower side, indicating the LED's 
cathode or negative end. Add the capacitors, 
pots, crystal, and transistor. The USB module 
is soldered to the board (Figure 7) using six thick 
wires in the positions indicated by the black holes 
in the diagram. Only two are used as signals - the 
others are for mechanical support only. Make sure 
you make the link on the module so that you get 
3V3 (3.3V) signals out of it. 


The VGA socket 

The socket is mounted on a bracket 
made from a 46mm length of 15x15 mm angle 
aluminium (Figure 8). This requires a trapezoidal 
slot to be cut out of it using a saw and file. The 
saw cuts you could make are shown in Figure 9; 
finish off by filing so the socket slots in neatly. 
Slot in the socket and mark its mounting holes 


V Figure 9 Saw cuts to remove 
the majority of the metal 


MägPi 
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Figure 11 Fitting 


Figure 10 Pre-wiring 
the VGA socket 


the VGA socket 


through the socket’s holes. Do the same with the 
bracket’s mounting holes on the board. Drill out 
with a 3mm drill and fix the bracket to the board. 


Wiring the VGA socket 

It is best if you add wires into the socket 
(Figure 10) before mounting it on the board. Add 
40mm wires to pin numbers 1, 2, 3, 9, 13, and 
14. Use different colours of wires for each one so 
they can easily identified once mounted. For the 
pin numbers 5, 6, 7, 8, and 10, you have to chain 
these together. Do this by stripping the ends off 
two wires and twisting them together, and then 
tinning them - that is, adding a bit of solder. ^eblioec 
Then trim off the exposed wire to about 4mm and Lok "ora 
insert in the hole of the pin, then solder it up. 


Figure 12 Tapping 
the power from 
the Pi 


The finished 
spin board 


"um um 


Ly 


"nnno 


X 


Adding the connection wires 

Screw the VGA socket to the bracket and 
wire up the flying leads to the points shown 
(Figure 11), trimming them to be only the length 
they need to be. Make the rest of the wires 
linking up the circuit. The 3V3, 5 V, and ground 
on the top of the layout go to the Raspberry Pi. 
We used three wires of 300 mm connected to an 
8-pin header socket pushed into the GPIO pins 
(Figure 12). Some VGA monitors don't require 
the 5V signal, so that could be omitted if that is 
the case with yours. 

With the hardware built, next month we will 

see how to program our spin board, test it, and 
get some funky sounds from it. 
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| You'll Need 


» Raspbian Jessie 
or newer 


> An image 
manipulation 
program such as 
GIMP, or images 
available from 
magpi.cc/nBSXKz 


The latest version 
of Pygame Zero 
(1.2) 


v 


v 


USB joystick or 
gamepad (optionaD 


v 


Headphones 
or speakers 


Code your own 
Pac-Man game: 


part 2 


Pac-Man captured the hearts and pocket money of many young 
people in the eighties. In part two of our guide, we add some 
groovy features to the basic game created last month 


Pac-Man gets points for eating dots, 
and ghosts after eating power-ups 


If all the dots are eaten, Pac-Man 
moves up a level; he has three lives 
before the game is over 


If Pac-Man eats a power-up, the 
ghosts turn blue and are edible 
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to move around, and restricted movement to 

just the corridors. We provided some dots to 
eat and some ghosts to avoid. In this part we are 
going to give the ghosts some more brains so that 
they are a bit more challenging to the player. We 
will also add the bonus power-ups which turn the 
ghosts into tasty edibles, give Pac-Man some extra 
levels to explore and some extra lives. So far in 
this series we have not dealt with music, so we will 
have a go at putting some music and sound effects 
into the game. 


| n part one, we created a maze for our player 


Need more brains 

In part one, we left our ghosts wandering 
around the maze randomly without much thought 
for what they were doing, which was a bit unfair 
as Pac-Man could evade them without too much 
trouble. In the original game, each ghost had 
a program that it followed to characterise its 
movements. We are going to add some brains to 
two of the ghosts. The first we will make follow 
Pac-Man, and the second we will get to ambush 
by moving ahead of Pac-Man. We will still leave in 
some random movement, otherwise it may get a 
bit too difficult. 


Follow the leader 
First, let’s get the red ghost to follow 
Pac-Man. We already have a moveGhosts() function 
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V Adding a brain to 
a ghost to follow 


the player 
from part one and we can add a condition to see 
if we are dealing with the first ghost: if g == @: fi gu re, py 
followPlayer(g, dirs). This calls followPlayer() 
if it's the first ghost. The followPlayer() function 
receives a list of directions that the ghost can 001. def followPlayer(g, dirs): 
move in. It then tests the x coordinate of the player 002. d - ghosts[g].dir 
against the x coordinate of the ghost and, if the 003. i d essor es 3 
direction is valid, sets the ghost direction to move 004. if player.x » ghosts[g].x and dirs[0] -- 1: 
toward the player. Then it does the same with 005. ghosts[g].dir = ð 
the y coordinates. 006. if player.x < ghosts[g].x and dirs[2] == 1: 
007. ghosts[g].dir = 2 
008. if d == @ or d == 2: 
009. if player.y » ghosts[g].y and dirs[1] -- 1 and not 
Y over x aboveCentre(ghosts[g]): ghosts[g].dir - 1 
The keen-witted among you will have 010. if player.y « ghosts[g].y and dirs[3] == 1: 
noticed that if x and y movements towards the 011. ghosts[g].dir = 3 
player are both valid, then the y direction will 012. 
always win. We could throw in another random 013. 
number to choose between the two, but in testing 014. def aboveCentre(ga): 
this arrangement it doesn't cause any significant 015. if ga.x » 220 and ga.x « 380 and ga.y » 300 and ga.y 
problem with the movement. See figure1.py for « 320: 
the followPlayer() function. You will see there isa 016. return True 
special condition aboveCentre() when we check the 017. return False 


downward movement. We are checking that the 
ghost is not just above the centre, otherwise it will 
go back into its starting enclosure. 


to time one ghost would get stuck in the centre. 
What we do is, if we detect that a ghost is in the 
centre, we always default to direction 3, which is 


The central problem up. If we run the game with this condition and 

If we go back to the moveGhosts() function, the followPlayer() function, we should see all 
we need another centre-related condition: if the ghosts making their way straight out of the 
inTheCentre(ghosts[g]). This is because if we leave centre and then the red ghost making a bee-line 
the ghost to randomly move around our centre towards Pac-Man. 


enclosure, it may take a long time to get out. In 
part one, you may have noticed that from time 
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figure2.py 


It’s an ambush! 

001. # This code goes in the update() function So, the next brain to implant is for the 
002. second ghost. We will add a function ambushPlayer() 
003. if player.status -- 1: in the same way we did for the first ghost, but this 
004. i = gameinput. (player) timeif g -- 1:. The ambushPlayer() function 
005. itd ss d works very much like the followPlayer() function, 
006. player.status - 0 but this time we just check the direction that 
007. player.x - 29€ Pac-Man is currently moving and try to move in 
008. player.y - that direction. We, of course, cannot know which 
009. direction the player is going to move, and this may 
010. # This code goes in the gameinput module seem a bit of a simplistic approach to ambushing 
011. # in the checkInput() function the player, but it is surprising how many times 
012. Pac-Man ends up wedged between these two ghosts 
013. if joystick count > 0: with this method. 
014. jb = joyin. (1) 
015. else: 
016. jb = 
017. if p.status -- 1: Scores on the doors 
018. if key. ()[K RETURN] or jb: Brain functions could be added to all the 
019. return 1 ghosts, but we are going to leave the ghost brains 

for now as there is plenty more to do to get our 


A Checking to see if ENTER 
or button A has been 
pressed and resetting the 
player actor 


Y Pac-Man gets three lives 
You can use the gamepad 
or joystick buttons to ask 
for input from the player 


# Load in the player Ac 
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game completed. Before we go any further, we 
ought to get a scoring system going and reward 
Pac-Man for all the dots eaten. We can attach the 
score variable to the player actor near the top of 
our code with player.score = e and then each 
time a dot is eaten we add 10 to the score with 
player.score += 10. We can also display the score 
in the draw() function (probably top right is best) 
with screen.draw.text(). 


figure3.py 
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07 Three strikes and you're out! 
As is the tradition in arcade games, you 

get three lives before it's game over. If you 
followed our previous tutorial for Space Invaders, 
you will know how we do this. We just add a lives 
variable to the player actor and then each time 
Pac-Man is caught by a ghost, we take a life off, 
set player.status = 1, and print a message to say 
press ENTER. When pressed, we set player.status 
= 0 and send Pac-Man back to the starting place. 
Then we continue. Have a look at figure2.py to see 
the code we add to reset Pac-Man to the start. 


Printing lives 

We have the system for keeping track of 
the player. lives variable, but we also need to 
show the player how many lives they have left. 
We can do this with a simple loop like we used in 
the previous Space Invaders tutorial. We can have 
a drawLives() function which we call from our 
draw() function. In that function, we go round a 
loop for the number of lives we have by saying for 
1 in range(player.lives): and then we can use 
the same image that we use for the player and say 
screen.blit("pacman o", (10+(1*32),4@)). 


001. 
002. 
003. 
004. 
005. 
006. 
007. 
008. 
009. 
010. 
011. 
012. 


013. 
014. 
015. 
016. 
017. 


018. 
019. 
020. 
021. 
022. 
023. 
024. 
025. 
026. 
027. 
028. 


029. 
030. 
031. 
032. 


it This code is in our main code file (pacman2.py) 


def initDots(): 
global pacDots 


pacDots - [] 
a=x=0 
while x < 30: 
y=0 
while y < 29: 
d = gamemaps.checkDotPoint(10+x*20, 10+y*20) 
if d == 1: 
pacDots.append(Actor("dot", (10+x*20, 
90+y*20))) 
pacDots[a].status = @ 
pacDots[a].type = 1 
at=1 
if d == 2: 
pacDots.append(Actor("power", (10+x*20, 
90+y*20))) 
pacDots[a].status = @ 
pacDots[a].type = 2 
at=1 
yt=1 
X t= 1 


# This code is in the gamemaps module 


def checkDotPoint(x,y): 
global dotimage 
if dotimage.get at((int(x), int(y))) 
Color('black'): 
return 1 
if dotimage.get at((int(x), int(y))) == Color('red'): 
return 2 
return False 


Which button to press 

You may notice in figure2.py that in our 
gameinput module we are checking a joystick 
button as well as the ENTER key. You may want to 
do a few tests with the gamepads or joysticks that 
you're using, as the buttons may have different 
numbers. You can also prompt the player to press 
(in this case) the A button to continue. If you were 
designing a game that relied on several buttons 
being used, you might want to set up a way of 
mapping the buttons to values depending on what 
type of gamepad or joystick is being used. 


A Updated code to 
include the creation 
of power-ups 


| have the power! 
The next item on our list is power-ups. 


These are large glowing dots that, when eaten, turn 
all the ghosts dark blue. In their blue form they can 
be eaten for bonus points and they return to the 
centre of the maze. First, let’s devise a way to place 
the power-ups in the maze. We have updated the 
pacmandotmap.png image to include some red 
squares, instead of black, in the positions where we 
want our power-ups to be. Then, when we initialise 
our dots and call checkDotPoint(x,y), we look for 
red as well as black - figure3.py shows how we 
change our code to do this. 
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gamemaps.py 


» Language: Python 3 


001. 
002. 
003. 
004. 
005. 
006. 
007. 
008. 
009. 


010. 
011. 
012. 
013. 
014. 


015. 
016. 


017. 
018. 
019. 
020. 
021. 
022. 
023. 
024. 
025. 
026. 
027. 
028. 


029. 
030. 


031. 
032. 


033. 
034. 


035. 


from pygame import image, surface, Color 
moveimage = image.load('images/pacmanmovemap.png') 
dotimage = image.load('images/pacmandotmap.png') 


def checkMovePoint(p): 
global moveimage 
if p.x+p.movex < 0: p.x = p.x«600 
if p.x+p.movex > 600: p.x = p.x-600 
if moveimage.get_at((int(p.x+p.movex), int(p.y+ 
p.movey-80))) !- Color('black'): 
p.movex - p.movey - € 


def checkDotPoint(x,y): 
global dotimage 
if dotimage.get at((int(x), int(y))) -- 
Color('black'): 
return 1 
if dotimage.get at((int(x), int(y))) -- 
Color('red'): 
return 2 
return False 


def getPossibleDirection(g): 
global moveimage 
if g.x-20 < 0€: 
g.X = g.x+600 
if g.x+20 > 600: 
E.X = g.x-600 
directions = [0,0,0,0] 
if g.x+20 < 600: 
if moveimage.get_at((int(g.x+2@), 
int(g.y-80))) == Color('black'): directions[@] = 1 
if g.x < 600 and g.x >= €: 
if moveimage.get_at((int(g.x), int(g.y-60))) 
== Color('black'): directions[1] = 1 
if g.x-20 >= 0: 
if moveimage.get at((int(g.x-20), 
int(g.y-80))) == Color('black'): directions[2] = 1 
if g.x < 600 and g.x >= 0€: 
if moveimage.get at((int(g.x), int(g.y-100))) 
-- Color('black'): directions[3] - 1 
return directions 


Not all dots are the same 

We now have a system to place our power- 
ups in the maze. The next thing to do is to change 
what happens when Pac-Man eats a power-up 
compared to a normal dot. At the moment we 
just add ten points to the player's score if a dot is 
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E A There were 255 levels in the original 
Pac-Man arcade game. The 256th level 

was unplayable as the screen layout was 
corrupted, but few people ever saw that 


eaten, so we need to add more code to handle the 
event of a power-up being eaten. In the draw() 
function, where we look to see if the player has 
collided with a dot using collidepoint(), we then 
check the status of the dot (to make sure it's still 
there) and after this we can add a new condition: 
if pacDots[a].type -- 


High status ghosts 

As we have determined that we are dealing 
with a power-up (type 2), we can add a loop that 
goes through the list of ghosts and changes the 
status of the ghost. Normally the status for a ghost 
is o. What we are going to do is change the status 
to a fairly high number (try 1200 to start with). This 
will indicate that the ghosts are in their alternate 
state and we will use the status as a countdown. 
We will decrement this value each time update() is 
called; when it reaches o, the ghosts will turn back 
to normal. 


Why so blue? 

To make our ghost turn blue, we are going to 
add some conditions to our drawGhosts() function. 
We want them to be blue when the status is more 
than 0, but just to make it interesting we will 
make them flash when they are about to turn back. 
So we can write if ghosts[g].status » 200 or 
(ghosts[g].status > 1 and ghosts[g].status%2 
== 0): ghosts[g].image = "ghost5". What this is 
saying is that if the status is over 200 then make 
the ghost blue, but if it's less that 200 but greater 
than 1 then make it blue every other frame. We 
then have an else condition underneath that will 
set the image to its normal colour. 
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gameinput.py 


» Language: Python 3 


001. from pygame import joystick, key 021. if key.get pressed()[K RIGHT] or xaxis > 0.8: 
002. from pygame.locals import * 022. p.angle = @ 

003. 023. p.movex - 20 

004. joystick.init() 024. if key.get pressed()[K UP] or yaxis « -0.8: 
005. joystick count - joystick.get count() 025. p.angle - 90 

006. 026. p.movey - -20 

007. if(joystick count » 0): 027. if key.get pressed()[K DOWN] or yaxis > 0.8: 
008. joyin - joystick.Joystick(0) 028. p.angle - 270 

009. joyin.init() 029. p.movey - 20 

010. 030. if joystick count > 80: 

011. def checkInput(p): 031. jb = joyin.get button(1) 

012. global joyin, joystick count 032. else: 

013. xaxis - yaxis - 0 033. jb = 0 

014. if p.status == 0: 034. if p.status == 1: 

015. if joystick count > 0: 035. if key.get pressed()[K RETURN] or jb: 

016. xaxis - joyin.get axis(0) 036. return 1 

017. yaxis - joyin.get axis(1) 037. if p.status -- 2: 

018. if key.get pressed()[K LEFT] or xaxis « -0.8: 038. if key.get pressed()[K RETURN] or jb: 

019. p.angle - 180 039. return 1 

020. p.movex - -20 


The tables have turned figure4.py 


Now we have our ghosts all turning blue 
when a power-up is eaten, we need to change what 


happens when Pac-Man collides with them. Instead 001. # This code is in the update() function 

of taking a life from the player. lives variable, we 002. 

are going to add to the player.score variable and 003. for g in range(len(ghosts)): 

send the ghost back to the centre. So, the first job 004. if ghosts[g].status » 0: ghosts[g].status -- 1 
is to add a condition in update() when we check the 005. if ghosts[g].collidepoint((player.x, 

ghost collidepoint() with the player, which would player.y)): 

beif ghosts[g].status > @:. We then add 100 to 006. if ghosts[g].status > ð: 

the player.score and animate() the ghost back to 007. player.score += 100 

the centre. See figure4.py for the updated code. 008. animate(ghosts[g], pos-(290, 370), 


duration-1/SPEED, tween-'linear', 
on finished-flagMoveGhosts) 


009. else: 
Back to the start 010. player.lives -- 1 
You will notice that when Pac-Man comes 011. if player.lives -- 0: 
into contact with a dark blue ghost, we just 012. player.status - 3 
animate the actor straight back to the centre in the 013. else: 
same time that we normally animate a ghost from 014. player.status - 1 
one position to the next. This is so that we don't 
hold up the animation on the other ghosts waiting 
A Updated ghost 
for the eaten one to get back to the centre. In the collision code:to 
original game, the ghosts would turn into a pair of Time for some music s id cis e 
eyes and then make their way back to the centre So far in this series, we have not covered eats then Md 
along the corridors, but that would take too much adding music to games. In the documentation of 
extra code for this tutorial. Pygame Zero, music is labelled as experimental, 
so we will just have to try it out and see what 
happens. In the sample GitHub files for this 
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pacman2.py 


tutorial, there is a directory called music and > Language: Python 3 


in that directory is an MP3 file that we can use 


as eighties arcade game background music. 001. import pgzrun 

To start our music, all we need to do is write 002. import gameinput 
music.play("pm1") in our init() function to start 003. import gamemaps 

the music/pm1.mp3 file. You may also want to set 004. from random import randint 
the volume with music.set volume(0.3). 005. from datetime import datetime 


006. WIDTH - 600 
007. HEIGHT - 660 


008. 
17 More sound effects 009. player = Actor("pacman o") # Load in the player Actor image 
The MP3 file will continue playing in a 010. player.score - 0 
loop until we stop it, so when the game is over 011. player.lives - 3 
(player.lives = 0) we can fade the music out with 012. level = ð 
music.fadeout(3). At this stage we can also add 013. SPEED - 3 
some sound effects for when Pac-Man is eating 014. 
dots. We have a sound in our sounds directory 015. def draw(): # Pygame Zero draw function 
called paci.mp3 which we will use for this purpose 016. global pacDots, player 
and we can add a line of code just before we 017. screen.blit('header', (0, @)) 
animate the player: sounds.pac1.play(). This will 018. screen.blit('colourmap', (0, 80)) 
play the sound every time Pac-Man moves. We can 019. pacDotsLeft = 0 
do the same with pac2.mp3 when a life is lost. 020. for a in range(len(pacDots)): 
021. if pacDots[a].status == 
022. pacDots[a].draw() 
023. pacDotsLeft += 1 
Level it up 024. if pacDots[a].collidepoint((player.x, player.y)): 
The last thing we need to put into our 025. if pacDots[a].status -- 
game is to allow the player to progress to the next 026. if pacDots[a].type -- 
level when all the dots have been eaten. We could 027. for g in range(len(ghosts)): ghosts[g].status - 1200 
incorporate several things to make each level 028. else: 
harder, but for the moment let's concentrate on 029. player.score += 10 
resetting the screen and changing the level. If we 030. pacDots[a].status - 1 
define our level variable near the top of our code 031. if pacDotsLeft == 0: player.status = 2 
as level = ð, then inside our init() function we 032. drawGhosts() 
say level += 1, then each time we call init() we 033. getPlayerImage() 
will increase our level variable. This means that 034. player.draw() 
instead of saying that the player has won, we just 035. drawLives() 
prompt them to continue, and call init() to reset 036. screen.draw.text("LEVEL "+str(level) , topleft-(10, 10), owidth-0.5, 
everything and level up. ocolor-(0,0,255), color-(255,255,0) , fontsize-40) 
037. screen.draw.text(str(player.score) , topright-(590, 20), owidth=0.5, 
ocolor=(255,255,255), color=(@,64,255) , fontsize-60) 
038. if player.status -- 3: drawCentreText("GAME OVER") 
So much to do 039. if player.status -- 2: drawCentreText( 
The Pac-Man game has many more things "LEVEL CLEARED!XnPress Enter or Button A\nto Continue") 
that can be added to it. The original had bonus 040. if player.status == 1: drawCentreText( 
fruits to collect, the ghosts would move faster "CAUGHT!\nPress Enter or Button A\nto Continue") 
as the levels continued, there were animations 041. 
between some of the levels, and the power-ups 042. def drawCentreText(t): 
would run out quicker. You could add all of these 043. screen.draw.text(t , center-(300, 434), owidth-0.5, 
things to this game, but we will have to leave you ocolor=(255,255,255), color=(255,64,0) , fontsize=60) 
to do that yourself. Take a look into the history of 044. 
the Pac-Man game - it's fascinating - and we will 045. def update(): # Pygame Zero update function 
be starting a new Pygame Zero game in the next 046. global player, moveGhostsFlag, ghosts 


instalment of this series. Ll 
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DOWNLOAD 
THE FULL CODE: 


© magpi.cc/TDtRaV 
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if player.status -- 
if moveGhostsFlag -- 4: moveGhosts() 
for g in range(len(ghosts)): 
if ghosts[g].status » 0: ghosts[g].status -- 1 
if ghosts[g].collidepoint((player.x, 
player.y)): 
if ghosts[g].status > 0: 
player.score += 100 
animate(ghosts[g], pos-(290, 370), 
duration-1/SPEED, tween-'linear', 
on finished-flagMoveGhosts) 
else: 
player.lives -- 1 
sounds.pac2.play() 
if player.lives -- 
player.status - 3 
music.fadeout(3) 
else: 
player.status - 1 
if player.inputActive: 
gameinput.checkInput(player) 
gamemaps . checkMovePoint(player) 
if player.movex or player.movey: 
inputLock() 
sounds.paci.play() 
animate(player, pos=(player.x + player. 
movex, player.y + player.movey), duration=1/SPEED, 
tween- linear', on_finished=inputUnLock) 
if player.status -- 
i = gameinput.checkInput(player) 
if i zz 
player.status = 0 
player.x = 290 
player.y = 570 
if player.status == 
i = gameinput.checkInput(player) 
if iss 
init() 


def init(): 
global player, level 
initDots() 
initGhosts() 
player.x = 290 
player.y = 570 
player.status = 0 
inputUnLock() 
level += 1 
music.play("pm1") 
music.set volume(0.2) 


def drawLives(): 
for 1 in range(player.lives): screen.blit("pacman o", 
(10+(1*32) ,40)) 


def getPlayerImage(): 
global player 
dt = datetime.now() 
a = player.angle 
tc = dt.microsecond%(500000/SPEED) /(100000/SPEED) 
if tc > 2.5 and (player.movex != 0 or player.movey 
120): 


if a !- 180: 

player.image - "pacman c" 
else: 

player.image = "pacman cr" 

else: 

if a !- 180: 

player.image - "pacman o" 
else: 

player.image - "pacman or" 


player.angle - a 


def drawGhosts(): 
for g in range(len(ghosts)): 
if ghosts[g].x » player.x: 
if ghosts[g].status » 200 or (ghosts[g].status 
> 1 and ghosts[g].status%2 == 0): 
ghosts[g].image = "ghost5" 
else: 
ghosts[g].image = "ghost"+str(g+1)+"r" 
else: 
if ghosts[g].status > 200 or (ghosts[g].status 
> 1 and ghosts[g].statusX2 == 0): 
ghosts[g].image = “ghost5" 
else: 
ghosts[g].image = “ghost"+str(g+1) 
ghosts[g].draw() 


def moveGhosts(): 
global moveGhostsFlag 
dmoves = [(1,9),(0,1),(-1,0),(0,-1)] 
moveGhostsFlag - 0 
for g in range(len(ghosts)): 
dirs - gamemaps.getPossibleDirection(ghosts[g]) 
if inTheCentre(ghosts[g]): 
ghosts[g].dir - 3 
else: 
if g == 0: followPlayer(g, dirs) 
if g -- 1: ambushPlayer(g, dirs) 


if dirs[ghosts[g].dir] == ð or randint(0,50) == e: 
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140. d= -1 182. def ghostCollided(ga, gn): 

141. while d -- -1: 183. for g in range(len(ghosts)): 

142. rd = randint(0,3) 184. if ghosts[g].colliderect(ga) and g !- gn: 

143. if aboveCentre(ghosts[g]) and rd -- 1: 185. return True 

144. rd = 0 186. return False 

145. if dirs[rd] == 1: 187. 

146. d = rd 188. def initDots(): 

147. ghosts[g].dir = d 189. global pacDots 

148. animate(ghosts[g], pos=(ghosts[g].x 190. pacDots - [] 
+ dmoves[ghosts[g].dir][0]*20, ghosts[g].y + 191. a=x=6 
dmoves[ghosts[g].dir][1]*20), duration=1/SPEED, 192. while x < 30: 
tween-'linear', on finished-flagMoveGhosts) 193. y=6 

149. 194. while y « 29: 

150. def followPlayer(g, dirs): 195. d = gamemaps.checkDotPoint(10+x*20, 10+y*20) 

151. d = ghosts[g].dir 196. if d = 1: 

152. if d == 1 or d == 3: 197. pacDots.append(Actor("dot",(104x*20, 

153. if player.x > ghosts[g].x and dirs[0] == 1: 90+y*20))) 
ghosts[g].dir = e 198. pacDots[a].status = @ 

154. if player.x < ghosts[g].x and dirs[2] == 1: 199, pacDots[a].type - 1 
ghosts[g].dir = 2 200. at=1 

155, if d == @ or d = 2: 201. if d == 2: 

156. if player.y > ghosts[g].y and dirs[1] == 1 and not 202. pacDots . append(Actor( "power" , (10*x*20, 
aboveCentre(ghosts[g]): ghosts[g].dir - 1 90+y*20))) 

157. if player.y < ghosts[g].y and dirs[3] == 1: 203. pacDots[a].status = @ 
ghosts[g].dir = 3 204. pacDots[a].type = 2 

158. 205. at=1 

159. 206. yt=l 

160. def ambushPlayer(g, dirs): 207. x +2 1 

161. d = ghosts[g].dir 208. 

162. if player.movex > @ and dirs[0] == 1: ghosts[g].dir = 209. def initGhosts(): 

163. if player.movex < @ and dirs[2] == 1: ghosts[g].dir = 2 210. global ghosts, moveGhostsFlag 

164. 211; moveGhostsFlag - 4 

165. if player.movey » 0 and dirs[1] -- 1 and not 212. ghosts - [] 
aboveCentre(ghosts[g]): ghosts[g].dir - 1 213, g-2e 

166. if player.movey < 0 and dirs[3] == 1: ghosts[g].dir = 3 214. while g « 4: 

167. 215. ghosts.append(Actor("ghost"«str(g*1), (270*(g*20), 

168. def inTheCentre(ga): 370))) 

169. if ga.x » 220 and ga.x « 380 and ga.y » 320 and ga.y « 216. ghosts[g].dir = randint(0, 3) 
420: 217. ghosts[g].status = 0 

170. return True 218. g +=1 

171. return False 219. 

172. 220. def inputLock(): 

173. def aboveCentre(ga): 221. global player 

174. if ga.x » 220 and ga.x « 380 and ga.y » 300 and ga.y « 222. player.inputActive - False 
320 223 

175. return True 224. def inputUnLock(): 

176. return False 225. global player 

177. 226. player.movex = player.movey = 0 

178. def flagMoveGhosts(): 227. player.inputActive - True 

179. global moveGhostsFlag 228. 

180. moveGhostsFlag += 1 229. init() 

181. 230. pgzrun.go() 
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| aw to use your new computer 


THE OFFICIA, The only guide you 
need to get started 
with Raspberry Pi 


e Learn how to set up the Raspberry Pi, 
install an operating system, and start using it 


* Follow step-by-step guides to code your 
own animations and games, using both the 
Scratch and Python languages 


e Create amazing projects by connecting 
electronic components to the Pi's GPIO pins 


£10 with 
worldwide delivery 
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Evans 


PJ is a writer, 
software engineer, 
and Raspberry Jam 
organiser. Too much 
of his house now 
thinks for itself. 


mrpjevans.com 


| You'll Need 


> Raspberry Pi 
Touch Display 
magpi.cc/touch 


> Camera Module 
magpi.cc/camera 


> PIR sensor 
magpi.cc/vmqYLG 


> 2 x Security door 
contact reed switch 
magpi.cc/FDjbna 


> Wired doorbell 
magpi.cc/KFYWcQ 


» PAM8302 amplifier 
magpi.cc/mifFLc 


» Speaker 
magpi.cc/PwkasX 


» Magnetic access 
control system 
magpi.cc/rkEXYF 


Smart door 


Adding a Raspberry Pi to your door has magical results. Want to see who's at 
the door or know when the post has arrived? Control the lock? Read on... 


close. Snoozefest. Surely it can do more than 

that? How about a smart door that knows when 
someone approaches, when the post arrives, and 
can even offer remote viewing of the peephole? 
You can also add intelligent lighting, a controllable 
door lock, and facial recognition, all powered with 
your Raspberry Pi. So, let's ignore super-expensive 
door systems and build our own. You can do as 
much, or as little, as you like of this project and 
there's plenty of room for new and inventive uses. 


[ s your door a bore? Open and close, open and 


Prepare your Raspberry Pi 

Although you can use any WiFi-capable Pi, 
this is a perfect project for the new Raspberry Pi 
3A+. Start by attaching the Pi to the Touch Display 
and preparing a microSD card with the latest 
Raspbian Stretch release. To allow easier access 
and mounting, we’ve detached the control board 
from the back of the screen, taking great care of 
the ribbon cable. Eventually, they'll be put ina 
smart 3D-printed case. Now, get your Pi set up 
and make sure to sudo apt update && sudo apt 
upgrade before proceeding. 


Attach the camera 

We're going to keep an eye on the outside 
world by replacing the door’s peephole with the 
Raspberry Pi camera. A peep- hole is typically a 
two- piece barrel that screws together and can 
be easily unscrewed from the inside. Remove 
the barrel and cover the hole with the camera. 
We're just going to affix this with tape for now; a 
printed mount will come later. Mount the screen 
and Pi to the door (we used 3M Command strips), 
placed so you can attach the camera's ribbon 
cable to the Pi once it's shut down. Make sure the 
camera is enabled in Raspberry Pi Configuration 
or raspi-config. 
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Footsteps approaching! 

The first smart thing our door is going to 
do is detect someone approaching it. A cheap 
PIR sensor is perfect for the job. These cool little 
geodesic domes are triggered by heat and are 
the same gizmos that you find in motion-sensor 
lights, switches, and security systems. Connect 
to the Pi as shown in Figure 1, checking whether 
you have a 5V or 3.3V sensor. Sensitivity and 
duration of a ‘detection’ can be controlled by the 
two potentiometers on the PIR board. Mount this 
outside in a suitable location to *watch' your door. 


Y Figure 1 The GPIO wiring 
that's needed for the 
various inputs and outputs 


Doorbell 
PIR GPIO13 
GPIO17 Letterbox È Door 
&5V GPIO19 GPIO26 


Monitor the door and letterbox 
We have two magnetic reed switches, the 
type you find on windows and doors for security 
systems. They are made up of two parts: the wired 
part is a reed switch and the unwired a magnet. 
When the magnet meets the switch, it closes. If we 
attach the magnet to the door and the switch to the 
frame, when the door opens, so does the switch. 
There’s no polarity to worry about, so connect 
one wire to GPIO 26 and the other to the adjacent 
ground. Repeat for the letterbox using GPIO19. 
You may need a breadboard. 


Ding dong! 

Regular doorbells? Yawn. If we replace the 
doorbell with our own button, we can take a photo 
with the Pi Camera Module when someone presses 
it and send a notification. Way better. Mount a 
standard wired doorbell, which after all is just a 
momentary contact button, to the outside door 
frame and wire it back to the Pi using GPIO 13 and 
an available GND pin. If you're prototyping on a 
breadboard, a tactile switch will do fine. 


Sounds good 

There's little point in a doorbell that makes 
no sound. We can use the small, but surprisingly 
powerful, PAM8302 amplifier with a speaker to 
make some noise. Supply power by soldering 'Vin' 
to an available 3V3 pin on the Pi, and ground to 
GND. To get an audio signal, you can tap the audio 
connector's signal and ground, then connect 
them to A* and A- respectively. Finally, solder 
the speaker to the larger * and - terminals. 
When prototyping, you can skip this and use any 
active or passive speaker via the audio connector 
on the Pi. 


07 Code 
Double-check all your connections and 
power on the Pi. To use the code published here 
(overleaf), open a Terminal and enter: 


mkdir ~/smartdoor 
nano ~/smartdoor/smartdoor_test.py 


Now type in the code as shown. Alternatively, 
to download all the code: 
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The screen automatically 
displays video when 

an approaching person 

is detected 


Cheap and simple reed 
switches monitor the 
door and the letterbox 


cd 
git clone https://github.com/mrpjevans/ 
smartdoor 


To enable it to play our doorbell sample: 

sudo apt install mpg123 
Now test with: 

python3 ~/smartdoor/smartdoor_test.py 
Watch the console output. If everything is working, 
you should be able to trigger the PIR, the reed 
switches, and the doorbell. The camera will capture 
ten seconds of video when motion is detected, and 


a photo when the doorbell is pressed. These are 
both saved to the desktop. 


TopTip è 


Night is dark 


If you want the 
camera to work 
well at night, 

you may want 

to consider a Pi 
NoIR Camera 
Module supported 
with some 
infrared lighting. 
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P You may want to 
prototype this project 
and test it before 
taking a drill to 
your door! 


X The web app can run 
on the touchscreen, 
as well as on 
mobile devices or 
desktop browsers. 
Release the door 
from anywhere! 


TopTip è 


Get the 
right lock 


Magnetic door 
locks vary in 
size and shape; 
measure twice 
and order once! 


Get alerts! 

Let's make this useful. Install Pushover on 
your phone, head over to pushover.net, sign up for 
a trial account, then log in and make a note of your 
User Key (a long string of characters). Now create a 
new Application and give it a name. Once created, 
you'll see an API Token. Make a note of this too. 
From the GitHub repository, edit smartdoor.py 
and add the User Key and API Token where shown. 
Run this version and you'll get phone alerts for 
each event and even a photo attachment when the 
doorbell is pressed. 


Intelligent porch light 


Following on 
tutorial in The MagPi 
an external porch lig 
The file porch.py wil 
light to an API that p 


from the Tradfri lighting 


#75 (magpi.cc/75), if you have 
ht, why not make it smart! 
connect a Trádfri smart 
rovides sunrise and sunset 


times for your location. Leave the script running 


and the light will swi 


tch on and off at the correct 


times. Additionally, it monitors the PIR sensor 
and will switch to full brightness when someone 
approaches! To use the script, get your latitude and 
longitude (you can use Google Maps or Earth) and 
edit porch.py as directed in the file. 
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Door lock 

If you're interested in being able to 
control your door’s lock, you may see that some 
solutions are very pricey. One that is perfect for 
experimentation is the magnetic hold lock, which 
uses an electromagnet to hold the door closed. 
The one we've used can withstand 180 kg of force, 
although stronger ones are available. The magnet 
mounts on the door and the electromagnet on the 
frame. The provided PSU contains a relay that can 
be powered by the Pi by simply connecting it to a 
spare GPIO line and ground. Please note this is no 
replacement for a proper door lock system. 


Web app 

If would be great to see what our door has 
been up to remotely, so a web app seems the 
next logical step. In the directory called webapp 
is a Python script that uses Flask to provide a 
web server that is usable on mobile devices. You 
can take a photo from the peephole, see the last 
recorded video, and even control the magnetic door 
lock from Step 10. Simply run the app alongside the 
others. Better still, set smartlights.py, porch.py, 
and webapp/smartdoor.py to start on boot (see the 
repository README). 
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smartdoor test.py 


DOWNLOAD 
THE FULL CODE: 


» Language: Python 3 


© magpi.cc/dQyeQS 


001. from picamera import PiCamera 032. 
002. from gpiozero import MotionSensor 033. def doorClosed(): 
003. from gpiozero import Button 034. print('Door closed') 
004. from time import sleep 035. 
005. import os 036. def letterboxOpen(): 
006. import subprocess 037. print('You got mail!') 
007. import sys 038. 
008. 039. def doorbellPressed(): 
009. print('Getting smart...') 040. subprocess.Popen(['mpgi23', '/home/pi/ 
010. smartdoor/doorbell.mp3'], 
011. # Set up all our devices 041. stdout=subprocess.PIPE, 
012. camera = PiCamera() stderr-subprocess.STDOUT) 
013. motion - MotionSensor(17) 042. camera.capture(' /home/pi/Desktop/doorbell.jpg') 
014. doorSensor = Button(26) 043. print('Someone\'s at the door!') 
015. letterbox - Button(19) 044. 
016. doorbell - Button(13) 045. # Attach our functions to GPIOZero events 
017. 046. motion.when motion = motionDetected 
018. def motionDetected(): 047. motion.when no motion = motionStopped 
019. print('Motion detected, video recording') 048.  doorSensor.when pressed = doorClosed 
020. Os.system('DISPLAY-:0 xset s reset') # Wakes 049.  doorSensor.when released = doorOpen 
the display up 050. letterbox.when released = letterboxOpen 
021. camera.start_preview() 051. doorbell.when_released = doorbellPressed 
022. camera.start recording( 052. 
' /home/pi/Desktop/motion.h264') 053. print('Smart door is smart') 

023. sleep(10) 054. 
024. 055. # Loop forever allowing events to do their thing 
025. def motionStopped(): 056. try: 
026. print('Stopping video recording') 057. while True: 
027. camera.stop recording() 058. pass 
028. camera.stop preview() 059. except KeyboardInterrupt: 
029. 060. print('Smart door no longer smart') 
030. def doorOpen(): 061. except: 
031. print('Door open') 062. print('Oh dear') 

Facial recognition 

Once a futuristic technology, decent facial Over to you 


recognition is now well within the grasp of the 
Raspberry Pi. Using the doorbell photo taken by 
the Pi, we can recognise a face using reference 
photos and send an alert to Pushover with the 
name of the caller! In a secure environment, a 
recognised face could even trigger the lock or 

you could play a welcome announcement. The 
install process is a little complicated, so if this 
interests you, see the documentation in the GitHub 
repository in the face recognition directory of the 
‘smartdoor’ repository. 


Here we've given you the basics to get going, 
but more complex events are possible. You could 
alert different people based on facial recognition 
or play custom doorbell tones. And, if you had 
problems with deliveries, video evidence can build 
up automatically. On a serious note, remember a 
lot of this is ‘just for fun’ and designed to inspire, 
so unless you're prepared to put in the work 
hardening the code and including failsafes, don't 
rely on this, or possibly make it as a fun kids! door 
project (but maybe without the lock!). m 
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Richard 
Smedley 


Having often found 
words better than 
pointing at things, 
Richard stuck with 
the command line 
whence all around 
had fled. 


@RichardSmedley 


TopTip è 


Tape archive 


Tar dates from 

the days when 
computers 
backed up to big 
tape reels, those 
essential props 

of 1960s and 
1970s sci-fi films. 
The lack of file 
structure on tapes 
means that tar 
can save all of the 
file system info 
such as ownership 
and timestamps. 


ave it now! 


Protect your precious data with backups, 


and stop snoopers with disk wipes 


our data is the most important thing on your 
Raspberry Pi, and good backups are a useful 
discipline to take elsewhere. Fortunately, 
the command line can actually make this easier. 
The simplest method of all is to copy the data 
and move it elsewhere. It’s labour-intensive, 
compared to automatic solutions, but for only- 
very-occasional backups it's better than nothing. 
Whether you're copying to disk, or moving the 
backup to another machine, it's best to make it 
as small as possible. So you'll want to compress 
the file. We advise using the gzip compression 
format. You could go with xz or bzip2 compression 
(from tar, J or j options, respectively) for better 
compression to a smaller file size, but although 
alternatives to gzip save a little more space, they 
can take far longer to perform the compression. 
Taking a directory of files that needs collecting 
together, then compressing it, can be done with a 
single tar command: 


tar czvf mybackup.tgz myfolder 


Bill oiorespbenypi: -/bin g bashrc 


File Edit Search Options Help 
pi@raspberrypi: ~/bin 


S 


Edit Tabs Help 


"Li 
export PATH-"$PATH:$HOME/bin" ( ) 
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The c switch tells tar to create the archive, diving 
into all subfolders found; f, use the named file 
(here, mybackup.tgz), is necessary to direct the 
output away from the terminal. v asks for more 
verbose output, so the program tells you what it is 
doing and what (if anything) has gone wrong. Lastly, 
z invokes gzip compression. To unpack the archive, 
substitute x for extract in place of c - you can omit 
the z, as tar will recognise the compression type 
and automagically deal with it: 


tar xvf mybackup.tgz 


A safe home 

Often, using tar to back up /home/pi - with 

cd /home, then tar on the pi folder - will be all 
you need, but if you have data across directories, 
from /etc to /var/www, it’s simplest to back up 
the entire microSD card. This can be done on the 
Pi, with the microSD card you want to back up in a 


By putting commands in a .sh 
file and making it executable, 
you create your own scripts 


w 


to a separate f 


^ere directly. 


he bash-doc pacl 


you don't need 
h.bash d /e $ 
ashrc an e e - 
WE Making a -/bin folder and 
adding it to the PATH directive 
in ~/.bashrc means you'll be 


able to run your scripts by name 


USB card reader, with one important caveat: you'll 
be creating a file as big as the entire card - usually 
8GB or more - onto a Pi with less space to spare. 
The solution is to compress the image file as it is 
created, which, for a Pi with a modest amount of 
data on it, will result in an image of around 2.5GB. 

Use sudo fdisk -1 before and after plugging in 
the card, to check how it is labelled. If /dev/sdb 
appears, say, with the size equal to the microSD 
card, unmount it with umount /dev/sdb1. Then 
back it up with the command: 


dd bs=4M if=/dev/sdb | gzip > back-2018- 
12-04-raspbian.img.gz 


Open another Terminal tab and monitor your 
disappearing disk space with df - if you don’t 
think that it will fit, stop the dd operation with the 
usual CTRL+C, then rm (remove) the image file 
that you have partially created, and go and perform 
the backup on a computer with more disk space - 
or with a backup drive mounted, which you copy 
the archive to directly. Turning the backup into a 
usable microSD for the Pi means piping the other 
way, from gzip to dd: 


gzip -cd back-2018-12-04-raspbian.img.gz 
| dd bs-4M of-/dev/sdb 


For disk operations like dd, you'll need root 
permissions: you can prefix dd with sudo, but for 
saving the file outside of /home/pi you may also 
need sudo - which means typing it in front of 
gzip as well. 

This is only mildly inconvenient on the Pi, where 
sudo does not demand your password - but on a 
multi-user computer, or any setup with greater 
security, you need a reliable way of becoming the root 
user for every operation: running sudo -s will give 
you a shell with root permissions, but remember to 
exit afterwards. Alternatively, a chain of commands 
can be run with full admin permissions like so: 


sudo bash -c "gzip -cd back-2018-12-04- 
raspbian.img.gz | dd bs-4M of-/dev/sdb" 


Remote copy 

It's good to be able to make backups as required, 
using removable drives, but to move towards 
systematic backups you will need to copy across 
the network using SCP (secure copy protocol). To 


pi@raspberrypi: ~/Pictures = ox 


A SCP makes command-line 
copying to remote machines as 
easy as moving files around on 
your Pi 


copy your backup file to another machine, one that 
allows SSH login (so is running a SSH server), pass 
your login name with the command: 


scp -p back-2018-12-04-raspbian.img.gz 
pij92.168.0.207:/home/pi/bak/ 


You will then be prompted for the user password. 
Change the piQ to whatever your user name is on 
the remote machine, not the Pi you're copying 
from. The -p preserves information such as when 
the files were last accessed. Note that -P (capital p) 
can be used to specify a particular port number. 

Another Pi, with a static IP address and a plugged 
in USB disk drive, could be an inexpensive backup 
machine, as well as media server or whatever else 
your home or office needs. 

Because you're sending these commands 
through the Bash shell, you get all the usual Bash 
advantages, from TAB completion (just type bac, 
or however much of the file name is unique in 
your present working directory) to wildcards. 

If you have disparate archives in the same 
directory - such as www-backup-20181225.gz and 
data-backup-20181226.gz - copy them all with: 


scp -p ./*backup*gz pi@192.168.0.207:/ 
home/pi/bak/ 


So far so good, but there are possibilities to 
automate your backup process later in this guide, 
so the interactive element - having to givea 
password - would be better avoided. As long as you 
can maintain security in some other way, of course. 
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Which files? 


Apart from -, your 
project may have 
config files in /etc 
or even /opt, and 
under /var are 
logs, web config, 
and files - all of 
which you may 
have modified for 
a project. 


Key to logins 

When setting up a SSH server, you can generate 
keys with ssh-keygen - these keys can be used to 
provide passwordless login. You can copy them 
across to other machines manually, but a handy 
shortcut is to use the command ssh-copy- id: 


TopTip è 


Why remote? 


As well as being 
able to centralise 
backups for more 
than one machine, 
a remote backup 
protects you 

from unexpected 
disasters such as 
fire or flood where 
the Pi is. Fairly 
unlikely? Yes, 

but that doesn't 
stop you insuring 
your house. 
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A datestamp in our 
script means that we 
are not producing 

a backup with the 
same name each day 
we run it 


TopTip è 


Hash bang 


The shebang, or 
hash bang - #! 

- at the start of 
the script is an 
instruction to the 
program loader to 
run the program 
immediately 
afterwards (in 

the example in 
this guide, that's 
an interpreter 
directive to run 
/bin/sh) and pass 
the script as an 
argument to it. 


TopTip è 


Password free 


Using your key 
tologinisa 
convenience you 
quickly get used 
to - beyond SCP 
to your backup 
server, try it on 
any machine 
under your control 
that you have to 
log in to. 


pi@raspberrypi: ~/bin -5 


GNU nano 2.2.6 File: test.sh 


ssh-copy-id pi@192.168.0.207 


If you have more than one key pair, use -i to 
specify which .pub file you’re copying. -p allows 
you to specify an alternate port number. Now 
we're all set for remote backups - but if you do 
them regularly, you'll waste a lot of disk space 
duplicating unchanging data. 

Rsync lets you copy data in much the same way 
as SCP, but uses a delta-transfer algorithm to only 
transfer the difference between the copies of the 
source file on your disk and the remote, saved 
version. This both saves bandwidth used and avoids 
cluttering up your backup disk with multiple near- 
identical versions of a file. It’s also handy if you’re 
paying a cloud provider for storage and data transfer. 

If your version of Raspbian doesn’t have rsync, 
it’s just an apt-get away. Typically, rsync uses SSH 
for transport, but you can set up a server running 
an rsync daemon, and directly contact the rsync:// 
URL over TCP (defaults to port 873). In this case, 
set an RSYNC_PASSWORD environment variable or 
use the --password-file switch. 

While rsync is not a built-in Bash command, 
we're highlighting it here as part of the array of 
command-line utility choices users face when 
considering whether to employ built-in commands 
or try something more complex instead. In 
addition, there is the possibility of using version 
control systems, such as git, for both backing up, 
and tracking changes on, important files. 


Script-it-yourself! 

We have seen from early on how powerful Bash 
can be by chaining together a few commands; 
another way of putting commands together is to 
bundle them into a script - a short program simply 
comprising a small number of Bash commands, 
and known as a shell script. Take a look at this 
code - try typing it in to your favourite text editor, 
adjusting it for the IP address of your networked 
backup server, and backup folder location (or 
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change the scp line to a cp to a plugged-in backup 
drive), and saving it as test.sh. 


4! /bin/sh 

cd /home/pi 

tar czf mydocsbackup.tgz Documents 

scp mydocsbackup.tgz pi@192.168.0.207:/ 
home/pi/bak/ 


Then make the script executable with: 
chmod u+x test.sh 


...and run it with ./test.sh - any problems, 
then check the names, network address, and 
did you perform the ssh-copy-id step? Now we 
have a script that saves a folder, and copies it 
remotely, do you notice any potential problems? 
Each time you run it, it will overwrite the previous 
mydocsbackup.tgz, both locally and remotely. 
We need a way to put a timestamp on the 
backup name: 


#! /bin/sh 
TODAY=$(date +"%F") 


cd /home/pi 

tar czf mydocsbackup-"$TODAY" .tgz 
Documents 

scp mydocsbackup-"$TODAY".tgz 
pi@192.168.0.207:/home/pi/bak/ 


What we have done is set a variable - TODAY 
- to the current date, in YYYY-MM-DD format, 
which we can now access with $TODAY. You can run 
date +%F in the terminal - date --help will show 
you the many other format options. Now you can 
automate it by putting the script somewhere like 
/usr/bin (and with a better name than test.sh), and 
running it regularly with cron, as we covered in The 
MagPi #76 ‘Start and stop at your command?’ guide. 

Shell scripts tend to grow; there is always room 
for improvement. Here, you may want to back up 
more than one directory, for example, or use echo 
to let users know what the script is doing at each 
stage. You could even make it interactive, letting 
users choose which directories to back up. 

There are plenty of shell scripting tutorials 
online, and great books to take it further, but 
Raspbian itself holds many great shell scripts, from 
which you can learn. To see how a script can be 
organised to still be maintainable with over 1,000 
lines of code, have a look at /usr/bin/raspi-config. 


pi@raspberrypi: ~ 
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A Shred will securely overwrite 
(then optionally erase) files 
of sensitive data - or entire 
disk drives 


However grand or modest your scripting 
ambitions, don’t be afraid to try things out: build 
up gradually, and test your code each time, so you 
know where to look for any errors you introduce. 
Help is at hand from the Raspberry Pi forums, and 
pasting your code into shellcheck.net will give you 
valuable feedback - for example, advising you the 
cd line of our backup script should be: 


cd /home/pi || exit 


...in case the cd step fails - this is generally 
a good idea, although not so important in this 
particular case. Now that we have a choice of 
backup options, one task remains: securely getting 
rid of data from disks. This is a concern for anyone 
handling other people’s data, or just protecting 
their own privacy and security. 


Through the shredder 

Back in the 1960s, if you wished to cover your 
tracks, Mission Impossible told us it was done by 
the show opening’s taped mission assignment 
finishing, “This message will self destruct in ten 
seconds...”, and boom went the tape player. 

In these digital days, protecting privacy or 
security means understanding how a disk drive 
actually stores data, so that you don’t dispose 
of old disks under the mistaken impression that 
you’ve securely erased data, when you haven’t. 

Disk space is collected into blocks, sized typically 
at 4096kB, that are indexed by the file system with 
inodes so that the disk controler knows where to 
send the read head to retrieve information. SSDs 
and flash drives don’t have read heads, but still 
organise the data in a similar fashion. Most disk 
operations occur at the inode level - so moving a 
file between directories on the same disk partition 
is simply done by relabelling an inode. rm does 
not delete the data stored, just the reference to its 
blocks on the inode. 


Plug in a disk drive after someone has done 
rm -rfonitandit will look empty, but use a low- 
level utility and you'll have access to all of the 
jigsaw puzzle pieces needed to put the data back 
together again. So far, so NCIS, but can this be 
significant to the average Pi user? Given the range 
of projects out there, and the multifaceted data 
that they collect, to stay on the right side of new 
and future data protection laws it will be useful to 
know how to securely remove data from your disks. 


Caution 
Before we start erasing disks, think of the 
carpentry maxim, ‘measure twice, cut once’. It’s 
easy to erase the wrong disk or partition if you’re 
not paying attention. Given enough opportunities, 
most of us do it, and it’s often the lesson that 
teaches us to make proper backups! Running 
through other operations on the disk (mount, df, 
1s, umount), before erasing, works as a sanity check 
that you’re addressing the correct partition. 

Now to those blocks. You can overwrite every 
bit of information, either with all 1 digits, or with 
random data, using dd. Even then, with magnetic 
disks, it’s theoretically possible to recover the 
data, and multiple overwrites will be necessary - 
but before you worry about writing a script to do 
that, let us introduce shred, a utility that does just 
that, overwriting with as many passes as you select 
as a command switch (or defaulting to three): 


shred -vf -n 5 /dev/sdb 


Adding a -z switch will overwrite the random 
data shred has used, with zeroes, leaving a new- 
looking disk. -u will delete the file after the secure 
overwrite. Shred can also safely overwrite and/or 
remove individual files. M 


Conquer the 
Command Line Qe, 


For more terminal tutorials, take a 
look at our Essentials book, Conquer 
the Command Line. Discover the 
power of the command line to 
simplify complex tasks, or instantly 
carry out simple ones. 
magpi.cc/Essentials-Bash 
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Where am I? 


If you follow our 
tip on SSH keys 
everywhere, and 
end up hopping 
from machine 
to machine, 
remember to 
customise your 
Bash prompt 

so that you are 
always sure on 
which machine 
you're about to 
erase a file. 


JIDE 
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Coding games on the 
aspberry P11n C/C++ 


Let's shoot something by adapting our code to another genre 


Brian 
Beuken 


Very old game 
programmer, now 
teaching very young 
game programmers 
a lot of bad habits 
at Breda University 
of Applied Science, 
in the Netherlands. 


magpi.cc/YxaUVQ 


| You'll Need 


» Code:Blocks 
sudo apt-get 
codeblocks 


» GLM 
> stb. image.h 


» TilEd or 
similar map editor 


TopTip è 
Be creative 


Rather than 
dotting enemies 
around, give them 
spawn sites and 
use a pattern in 
their actions! 


ime to wrap up a year of solid learning with 

a review of all the things you didn't know 

you were learning, and see how we can take 
them a little further. 


Consider what we did! 

It might not seem like it, because we could only 

do a few things each month, but we have in fact 
covered rather a lot of concepts, and implementing 
them in code has exposed us to some of the 

core fundamental skills any aspiring C** game 
programmer needs to write games. 

There's still quite a long way to go to be at the 
triple-A lead coder level, but that will come with 
time and practice - exposing yourself to more 
advanced concepts and more C++ methods, as and 
when you need them. 

For now, though, let's really think about what we 
have given ourselves. 


Variables: We know we can manipulate variables, 
and that there are many types of variables. 


Flow control: We saw that our project flows from 
one instruction to the next, but that condition 
tests allow us to change the direction of our code 
between two options. 


Loops: We can create a loop to repeat a process 
until its done, or until a certain number of steps 
have been taken. 


Object control: We took our first real steps into the 
concepts of OOP (object-oriented programming) 

by collecting different bits of data into one overall 
object, which we were able to manipulate by 
changing some of the object's variables. 


Abstraction: We saw that by thinking of things 
in terms of an object, rather than as a collection 
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of variable sets, we can visualise that data set 
as a thing that does something... as we ask it to. 


Visualisation: Although we've only scratched the 
surface, we've been able to understand that our 
CPU and GPU do different things, and setting up 
our GPU to visualise things in different ways is a 
major achievement. 


Maths: Yes, we did some maths, and hopefully we 
saw that sometimes using more complex maths 
can be much easier than doing a long series of 
simpler equations. 


Graphic handling: We also managed to isolate 
the idea that an object's graphic isn't the object, 
but simply a visual representation of a thing. This 
makes it easier to conceptualise. 


Data representation: We not only managed to 
encapsulate custom data sets into our objects, 
but we also made use of some standard C++ data 
systems, like arrays and vectors. 


Libraries: A key point of C++ coding is being able to 
use code written by much smarter coders to perform 
complex things for us. We can print text on screen 
and use maths systems which might be way beyond 
our beginner's levels of comprehension. 


A core set of C** instructions: Using just maths, 
conditional tests, OOP principles, and very simple 
GPU, we were able to produce a nice 2D platform 
game which was simple to change to 3D(ish). The 
mantra of ‘simple code works best’ is something 
we should try to remember even when we do finally 
branch out to the more complex C++ features; it 
will make some of our tasks that much easier. 


Problem solving: By far the most important thing 
is that we started to view coding as a sequence of 
problems to be solved in logical ways. 


All of these points and a few more are now on 
show in your fully working (semi) 3D-viewed 
platform game. 

And to prove that it is all the same code in this 
final lesson, we'll use the same principles to create 
a small scrolling shooting game using almost all 
the same code and some new code. 

As before, we'll define a base graphic object, 
make a map, add some code to create objects in the 
map, update them, and let our player - this time a 
ship - travel through the map. 


Step by step 
Even though we have code from previous projects, 
we'll start a new project, but copy the files from 
the platform game as we need them. C++ class 
files should be as transportable and complete as 
possible. There will be a few things to tweak, but 
that's fine. 

We need a map, so all the map code is pretty 
usable with a few tweaks for flexibility. We 


A. Figure 1 Reuse the graphics but with a new long map 
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DOWNLOAD 


THE FULL CODE: 


- 
- 
- 
- 
- 


will even use the same graphics, but arrange 
them differently. 

We require the basic concepts of the 
SimpleObj again. 

We need a player, in this case a ship, so all new 
graphics have been supplied for moving objects. 

We need a camera, and we'll keep a slight 
sense of 3D visualisation, as before, by moving 
the camera around a little bit to show the angles; 
however, we're not doing a full 3D game. 

We need enemies... well, we're not doing quite 
the same enemies, but many of the code concepts 
are the same. 

So, we've got enough to work with. The biggest 
difference between this game and a platform 
game is that we don't need gravity: we assume 
the ships are all flying. We will make the scroll 
constant, so that the player ship stays central and 
also moves forward with the scroll. That is enough 
to get going. 


Flexibility, let's have some? 

One other important feature this time: we've made 
things much more flexible. Hard-coded, fixed- 
sized arrays are effective up to a point, but suppose 
we need different-size maps, with different 
graphics? Arrays limit us by requiring us to use the 
same size each time, but we know vectors are more 
variable, so let's use them. 

Even though we're not using a lot of textures, 
we don't really want to be loading the same texture 
two, three, four, or however many times. 

The same applies to shaders. Internally, a 
shader is nothing more than a little text file which 
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4 Figure 2 Pass the 


ammo, keep spitting 
out bullets, but 
remember to remove 
them as well! 


TopTip è 


Loading 
is better 


Time to move 
away from hard- 
coding things: 
being able to load 
txt files lets us 
load all kinds of 
things and change 
them without 
compiling. 


TopTip è 


KISS 


‘Keep It Simple, 
Stupid! is a 
coding mantra. 
Abstract away the 
hard work so you 
only need to think 
what you want to 
do. Simple code 
nearly always 
works best. 
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Getting started 
with Unity 


How to make a 
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A. Figure 3 Spawning 
some enemies 


is parsed and compiled. We know how to load 
things, so let’s just load these little .txt files 
when needed. 

These kinds of things are prime candidates for 
a bit of housekeeping. We can use simple STL 


m Game programming is especially concerned 


with performance: we should consider ways 
to avoid having 300 not yet visible objects Ej 


TopTip è 


Make the 
game playable 


As much as we 
can flood our 
game with hard- 
to-kill baddies 
and bullets, 
good games 
should never 
be so hard as to 
be impossible. 


systems like ‘map’, to allow us to load data from 
our stores and keep track of them only using 
what we need. Map is like an array, but instead 
of a numerical index to get our value, we can 

use a string to associate a file name with a value 
we need. 

You can see three new files/classes: 
ShaderManager, TextureManager, and 
LevelManager. They contain classes which will 
load things for us, when we need them, and keep 
track of them when we want to use them. All 
three new classes have explanations of what they 
do and why. 

Now, let's get a new game written. 


RocketBob 

Bob was our platform game's main character and 

we'll use a main ‘character’ again, but this time 

Bob is going to be a rocket ship - see Figure 1. 
Creating a new RocketBob class is simple 

enough: all we need to do is think about what 


actions we want the rocket to do. Mainly, that's 
going to involve moving forward at a steady pace, 
and up and down. We can also allow left and right 
movement, but only in addition to the constant 
forward motion. 

‘He’ should shoot: we can't have intergalactic 
warfare without a few bullets. We should also 
make sure he can't move into the solid areas 
of our map, which for this game will be a short 
tunnel filled with marauding waves of enemy 
ships, many of which shoot at us or attempt to 
ambush us. 

Now we know what he can do, the class is easy 
to create, and can be seen in the source code. 


The subjects of our aggression 
Enemies are going to mostly follow the same rules 
as platform game baddies, and collision with them 
is deadly, but we need to consider how we make 
them. Should we create them all at the start of a 
evel, or should we create them as we need them? 
This distinction is important: we have a 

airly small test map, so we could get away with 
defining 100, 200, even 300 enemies at the level 
initialisation and updating them even when they 
are not visible on our screen, but it’s an awful 
waste of processing time. We might only see 10- 
20 of them on screen at any given part of the map 
and what if you decide to create an even bigger 
map? Populating that map could take some time. 
We might need to place certain things at fixed 
points, though - see Figure 2. 

Game programming is especially concerned 
with performance, and so we should consider 
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ways to avoid having 300 not yet visible objects 
going through their updates and draw calls 
for no effect. 

But suppose we only had ten special objects or 
test points whose job is simply to trigger a wave of 
baddies once RocketBob is close enough to make it 
worth doing. That’s a much easier proposition. 

Creating Trigger objects means we can limit 
their update to testing if RocketBob is close, and 
if so, the Trigger itself can take responsibility for 
creating waves of baddies, before shutting itself 
down. See Figure 3. 

We’ve made a set of trigger classes, each of 
which can set in motion a specific wave of baddies 
or missiles at the right time and place. All we 
needed was a simple range test and the ability to 
create sequences of baddies from a simple list. 
Again, review the code. 

Our enemies themselves are not especially 
complex - the game difficulty comes mainly from 
the numbers of them active at a time and their 
relentless bullet shooting. There should be quite 
a few of them on screen, and predictable spawn 
patterns can help our player to blow them away 
before they get a chance to shoot. See Figure 4. 


Pass the ammo 
Bullets are also a simple type of object, easy to 
create when we press a fire key. We can have 

two types - dumb and targeted - and we'll try 

to create some variety with that. For targeted 
bullets, we use a vector between the shooter and 
its target to find the direction the bullet needs 

to travel, and turn that in to a unit vector which 
gives us consistent direction for the bullet. 
Because it's a unit vector (i.e. if we made ita 
triangle, the hypotenuse would be one unit long), 
we can increase the velocity of the bullet by 
multiplying by a scalar value. So different ships 
can have different-speed bullets. 


More power 

As with our platform game, we'll litter the level 
with a few power-ups, which we will use to create 
different firing states and perhaps create a few 
cool homing bullets. We could place them with 
triggers, but as they are rather simple singular 
objects, a standard placement is fine. 
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A. Figure 4 Get creative with 
the spawn; simple maths 
patterns are neat! 


And we're done 

That's it! Some simple logic for the baddies and 
a simple change of main character with a scroll 
that edges ever onward, and we have a totally 
different game. But this is the important part: 
using the same basic concepts of a simple 
object being used to derive various different 
objects which interact with an environment. 


Taking this forward 
Like our platform game, we could go to 3D 
with this; that isn't a massive challenge, 
but interaction in 3D space presents more 
problems than visualisation, and requires a 
better understanding of maths and also an 
awareness of some performance issues with 
our Raspberry Pi. 

For now at least, focus on 2D concepts until 
your programming skills feel ready for the 
new challenge. There's a wealth of retro-style 
games you can produce using this simple 
framework, which you can build up and develop 
into your own game engine. And when you are 
ready, there are dozens of good sites to take 
your first real steps into 3D. 

That's all for these lessons in core skills. 
We hope it has increased your confidence and 
given you a taste for C/C++ coding to make your 
own games. [il 
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Learn more about C 


levelopment on SBC's 
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Brian has a whole book on the subject of making games C and 
C++, called The Fundamentals of C/C++ Game Programming: 
Using Target-based Development on SBCs. Grab it here: 
magpi.cc/nUkjEt 
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CDP Studio is a development platform for industrial control systems, now coming with a free 
version for non-commercial use. The system can run on a Raspberry Pi, supports C++, open source 
libraries and has a large feature toolbox including GPIO, I2C and MQTT. Its built in GUI design tool 


and features lets you code less and do more. 


Free download on 


CDP Technologies AS 
Nedre Strandgate 29 

P.O. Box 144 

NO-6001 Alesund, Norway 


Tel: +47 990 80 900 
info@cdptech.com 
www.cdpstudio.com 
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200 pages of 


THE Official 
RASPBERRY PI 


PROJECTS BOOK 


VOLUME 4 


Amazing hacking and making projects 
from the makers of MdgPi magazine 


Inside: 
0 How to get involved with the Pi community 
@ The most inspirational community projects 
@ Essential tutorials, guides, and ideas 


@ Expert reviews and buying advice 


mm le e 
QT magpi.cc/store 


plus all good newsagents and: 


WHSmith BARNES&NOBLE 


7. Available on the GET IT ON 
€ App Store P» Google Play 
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RASPBERRY PI 


ACCESSORIES 


Our guide to the greatest add-ons, HATs, 
and expansions for your Raspberry Pi 


he Raspberry Pi is fantastic on its 
T own. With wireless LAN, Bluetooth, 
USB ports, the multitalented GPIO 
pins, and a full operating system, it really 
is a fully functional computer. 
What if you could make it better? Do 
more? Make certain functions easier? 
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This is where Pi add-ons and accessories 
come in - there are hundreds of extras 
you can get for your Raspberry Pi that will 
improve its already impressive specs. 
What add-ons should you get, though? 
We're here to show you the best the 
Raspberry Pi world has to offer. 


MéigPi 


We'll start with an important 

one. HAT stands for ‘hardware attached 
on top’ (it’s a backronym), and is a standard for 
add-ons. That means there are specific definitions of how 
a HAT can connect and work. All you need to be concerned 
with is that a HAT fits perfectly on top of a full-size 
Raspberry Pi, connecting to the GPIO pins. You will usually 
need to install extra software to get them working. 


While the HAT standard has recently 
been extended to different sizes, many 
companies have created their own term 
: E for add-ons that act like a HAT but 

IP: 10.0.0.19 = don’t quite meet the technical criteria. 


Men: 18/4948 17.97% Pimoroni coined pHAT, and Adafruit 


Disk: 978/1565 8% i 
: uses Bonnet, and other firms 


tend to use similar 
variations on the 

headwear theme 
or HAT. 


A HAT is an add-on, but an add-on isn't necessarily a HAT. 
Add-ons can be connected via USB, only specific GPIO pins, 
the camera port, etc. It's a catch-all term for something 
that you can add onto your Raspberry Pi in some way. 
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PROGRAMMING AND 
MAKER ACCESSORIES 


Improve your projects with these add-ons 


magpi.cc/xcsSpm 


price: £29 / $37 


his dual motor control 
oard by the folks at 
iBorg is a powerful 

nd robust way to use a 
aspberry Pi to control 
robot. As well as being 
ble to make the motors go 
forward and back, it can control 
the speed for more precise 
manoeuvring, and can take a 
wide array of power inputs. 


TH 
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magpi.cc/sense-hat 


Use it with: Robots, RC cars price: £32 / $40 


Developed for the Astro Pi mission, the Sense HAT is primarily a set of 
environmental sensors. It can detect pressure, humidity, temperature, and 
orientation/movement. It also has an 8x8 LED matrix and a little joystick for 
very basic display and control. There are a couple of Sense HATs running on 
Raspberry Pi boards up on the ISS at the moment. 


Use it with: Weather stations, space stations 


ee et ee e 


Hologram Nova 


hologram.io/nova 
price: From £50 / $64 


Despite the world’s best efforts, WiFi is not 
available absolutely everywhere yet. You can’t even plug an 
Ethernet cable into a tree! The Nova solves this problem by letting you connect 
to cellular networks around the world on your Pi via this simple USB device. 


Use it with: Portable projects, outdoor cameras 
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Edge TPU Accelerator 


magpi.cc/TFLQpM MN 
price: TBC "d // ~~ 
Google was responsible for the AIY M 
Voice Kit we gave away with issue tt40 : ^5 


of The MagPi - a special HAT and 
extras that lets you turn your 


Pi into an AI voice Of 


Foe epee fo (os pep d 


Cluster HAT 


assistant. The Edge / Á 
TPU accelerator ¢ f i 
aims to help the Pi out ] /Á/ f f magpi.cc/Qrshbi 


with AI tasks, and make price: £29 / $37 


your voice assistants better. 


Putting Raspberry Pi boards 
into a cluster isn’t too difficult, 
but the Cluster HAT makes it 
very easy indeed. Using one 
Raspberry Pi, you can distribute 
computing to up to four Pi 
Zeros. Cluster computing is a 
great way to perform different 
kinds of calculations. 


Use it with: Voice control, Al projects 


s====== M] 


See ee m me e mn mn e m e ṣe „an a A 


8 ax 299 eae ed on r- 


€). 128x64 MONO BF A HAT! 


Use it with: Mathematics, 
big algorithms 
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Ultimate GPS HAT 


magpi.cc/vmPqLL 
price: £29 / $37 


GFX HAT 


magpi.cc/ZWvcLG £20 / $25 


track the precise location of your 
Raspberry Pi - well, as precise 

as GPS can be. You'll have to 
combine the position data with 
map data to make much use out 
of it, but once you have it all 
working it's pretty fantastic. 


A very functional screen that draws a lot less power than most displays, it also 
includes six capacitive touch buttons for control. It’s the successor to an excellent 
add-on known as Display-O- Tron, and makes interactive projects look great. 


Use it with: Thermostat, practical projects 
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Using a Raspberry Pi for - - - 
enterprise? You may want ) 4 hud AMARE hy c 
to check these out... 


O ©- | 
magpi.cc/FnezCP d o O. ; i 
to / $28 | 2 EE 
c o ooo 
Another remote-control power o 


solution, this one is designed 
for the Pi to control power 
elsewhere. There are various 
Energenie Pi-mote products, 
the cheapest starting at £10, 


, Raspberry Pi PoE-HAT | ' 
€) Raspberry. Pi 201% 


but the starter kit version also magpi.cc/aqpwZc £18 / $21 

includes compatible sockets. 

You can even get a Pi-mote that The Raspberry Pi 3B* is the first Pi model to include proper Power-over- 
allows the plugs to talk to the Pi Ethernet support, although you need one of these HATs to get it working. 
as well. Of course, the network needs to be set up to support (i.e. power) the PoE 


Use it with: Timed-lighting, and Raspberry Pi combo. It also currently only works on the Raspberry Pi 3B*. 


some loT Use it with: Server racks, headless solutions 


magpi.cc/merPpf 
£20 / $26 


Ne —. i . " 
Sony toad O7] Serious Raspberry Pi users often need power management and a real 


time clock (RTC) for various reasons. The Witty Pi 2 offers these things, 
along with some extra on/off functions that can programmed. As the 
Raspberry Pi normally requires the internet to check the time, an RTC is 
essential for scheduling tasks on a Pi that's not online. 


Use it with: Industrial settings, automated solutions 
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dinrplate.com 
£10 / $13 


Want to use a Raspberry Pi in a server environment, but don’t 
need a UPS or RTC or any of the advanced stuff like that? 

Just have some DIN rails handy anyway? Then the DINrPlate 
is an excellent add-on that lets you mount a Pi to a DIN rail 
without any fancy extras. And the price reflects that. 


Use it with: DIN rails, DIY servers 


magpi.cc/ZvcsrZ £17 / $22 p c magpi.cc/rfBfvo 
price: £200 / $256 


Are you a sysadmin in a big 
company that would like to use 
Raspberry Pi boards? The Strato 
Pi turns a Pi into a server good 
enough to pass the rigorous 
tests of enterprise IT. It has an 
impressive list of features: RTC, 
UPS, two-module DIN-rail case, 
RS-485, and more. 


Use it with: Enterprise, servers 


© On/off switch solutions for the Raspberry Pi 
have been around as long as the Pi itself, 
(&) but none of them has been that great. 
Along comes the Hackable Pi Switch Cap 
from Nanomesher and finally we have 
one that does everything you need. By 
default, it allows you to turn the Pi on 
and off with a button, and you can 
reprogram it to do more with an 
(9 included remote. 
(a) (w) Use it with: Desktop Pi, HTPC Pi 
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Improve your listening, watching, and more 


magpi.cc/aimAyy 

price: £23 / $29 

There are many digital-to-analogue converters (DACs) 
that turn your Pi into a powerful stereo, but we're pretty 
partial to the HiFiBerry DAC* range. There are cheaper 


versions, smaller versions, more powerful versions, and 


all of them let the Pi sound a bit better than normal. d 


Use it with: Stereo system, PA 
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magpi.cc/WgSmAA 
£40 / $50 


HifiBerry OAC+, HW 1.0 
wwv.hifibery.com 


The HyperPixel 4.0 is a massive, wonderful screen for 
the Pi that you can get with or without a capacitive 
touch function. It's dead simple to set up and, due to 
the high pixel density, it's great for watching media 
or looking at pictures. 


Use it with: Portable media projects, wall screens 


magpi.cc/2ve6iUo 
£6 / $8 


P If you're playing retro games with your Raspberry Pi, you 

g might want a retro controller to help it feel more authentic. We 
recommend one of the many versions of the classic SNES controller, 

with enough buttons to play any game prior to 1996 and some afterwards as well. 


Use it with: Retro games console, RC car projects 
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magpi.cc/ryviXi price: £23 / $25 flirc.tv 
W. , 2 : r : £20 / $23 
The official Raspberry Pi TV HAT is pretty amazing - its most basic 


function is allowing you to tune into TV signals using your Pi. That's pretty 
standard, but the amazing part is its ability to stream said TV not only around good standards these days, 
your network, but also over the internet if you're abroad and missing the and for stuff like Kodi there 
latest episode of GBBO. are plenty of ways to control 


your Pi-based HTPC via your 
phone or tablet. FLIRC makes 
the whole thing a bit simpler, 
though: take your favourite 
remote, let FLIRC know which 
button is which, and then just 
plug it into your HTPC. Simple. 


Remote controls do have some 


Use it with: DIY DVR, TV anywhere 


Use it with: Kodi setups, remote- 
controlled loT 


lightberry.eu 


£95 / $120 


Ever wanted your films to expand out of your TV? With Lightberry, you can 
install DIY Ambilight-like effects to your TV so that special effects become 
just that little bit more special. There are various kits to choose from as well. 


Use it with: HTPCs, magic mirrors 


magpi.cc/BupAFF 
£15 


The Picade is Pimoroni's 
excellent tabletop arcade kit, 
and its newest iteration is 
controlled by the powerful 
Picade X HAT. It's so good, 
they made it so you could buy 
it separately to use in your own 
DIY Pi arcade setup. 


Use it with: Arcade builds, 
remote controls 
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PiDP-11 


> Obsolescence Guaranteed » magpi.cc/wgWNTC > From $250 


Turn a Raspberry Pi into a blinktastic classic 1970s computer? 
PJ Evans puts on his Paisley shirt and heats his soldering iron 


DIMENSIONS: 


17x31x6 cm 


MODEL: 
PDP-11/70 


ARCHITECTURE: 
16-bit 


0S: 
RSX-11M Plus 


BLINKENLIGHTS: 
64 


W Aback panelis 
provided with cut-outs 
for popular connectors, 
or you can leave it open 
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in the 1960s was a defining moment 

in computing history, laying down the 
foundations of the hardware and software 
architectures we use today. Both it and the later 
PDP-11 were not only powerful machines, but also 
beautifully designed objects. 
Oscar Vermeulen, an admirer of PDP range, has 
sold over 2,000 of his PiDP-8 replica: a Raspberry 
Pi-powered emulator with a fully functional one- 
third scale front- panel. Now comes his PiDP-11 kit. 
Released in 1970, the original PDP-11 is the most 
successful ‘mini’ computer in history, with over 
600,000 sold. 


T he launch of Digital’s PDP-8 minicomputer 


Remarkable replica 

For this new kit, a painstaking process has resulted 
in an injection- moulded replica of the original 
PDP-11's case. If not for the one-third scale, you 
would struggle to tell it apart from the real thing. 
A perfect facia and custom-built switchgear 
complete the package. You even get a key and lock, 
just like the real thing. 


A The completed PiDP-11 on 
the provided wooden stand 


Once built, the PiDP-11 PCB comprises 64 LEDs, 
two rotary encoders, and an array of switches that 
connect to the Pi's GPIO. Running a special version 
of the SimH emulator, the Pi accurately handles 
input and output from the panel. You can hook 
up a screen if you wish, use SSH, or go old-school 
and implement RS-232. The back panel is provided 
with different cut-outs to suit your cabling. 


Digital-it-yourself 

The PiDP-11 is supplied in kit form and there's a 
lot to do. You'll need to have some experience in 
soldering to put this together, the focus being on 
accurately fitting the switches and LEDs. This is 
tricky, but Oscar has provided jigs that make the 
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Verdict 


hoops to jump through, but nothing too arcane The PiDP-11 ticks 


An essential purchase for 


and the steps are well explained. all the boxes. It's 
a nyo n e with a n | nte rest Once you log in, you're st raight into the PDP- 11's straightforward to 
operating system, an early form of UNIX. A number build, beautifully 
in com D utin g histo ry of alternative OSes are available, with more cased, and 
promised soon. You can switch back to Raspbian is endlessly 
any time you like. In fact, as SimH doesn’t put a E 
alignment of all these components much easier lot of strain on the Pi, it is unlikely to struggle with ee i 
than with the PiDP-8. The instructions are in other server tasks. As a result, many users have computing or 
an alpha stage, but they are clear and the switch their PiDPs doubling up as file or media servers. hypnotic flashing 
section is especially detailed. It took us about five These kits are a labour of love for Oscar and the lights, you'll 
hours to complete. attention to detail shines through, from the quality be delighted. 
Full instructions are provided on how to prepare of the casing to the extensive labelling on the PCB. 
the Pi for its new career in 1970s computing. At You many find the price high, but the quality is 9 
the time of publication, a one-stop SD card image there to match. An essential purchase for anyone 
should be available. Otherwise, there are a few with an interest in computing history. /10 
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Picade Console 


> Pimoroni » magpi.cc/BSeTDD » £60 / $64 


The Picade's smaller sibling is an awesome compact console 
to plug into your TV. Phil King enjoys some mare retro gaming 


BOARD: 

Picade X HAT 

CONTROLS: ollowing the arrival of a brand new version work, but we'd recommend a Pi 3B* for emulating 

Joystick, F of the Picade - reviewed in The MagPi #74 some of the more powerful retro systems. 

6 x arcade (magpi.cc/74) - Pimoroni has given the 

buttons, 4 x same treatment to the Picade Console. Unlike its Putting it together 

utility buttons, bigger brother, this retro gaming machine lacks The lack of a screen does make the Picade Console 

suasit its own screen, so you need to connect it up to a a whole lot easier to assemble than the full-size 
TV or monitor via HDMI. It does, however, pack an Picade. Made up of five black powder-coated 

SPEAKER: internal speaker so you'll still get sound even if your MDF panels (with helpful labels), its ‘cabinet’ is 

Snes 42 monitor doesn't have any. All you need to add is an essentially identical to the Picade's control console 

DIMENSIONS: HDMI cable, microSD card (with the RetroPie OS section, but with an extra rear cut-out for the 

245x120x140 mm on it), and a Raspberry Pi - any 40-pin model will Pi's HDMI port. Assembly instructions are on the 


> Acompact console, it 
packs all the features 
of the full-size Picade 
apart from the screen 
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A You can plug it into 
any TV or monitor 
with an HDMI port 


back of an A3 poster, or you can use the online 
ones (magpi.cc/wxbMLu). 

It took us around an hour to put together. The 
panels are connected using plastic brackets and 
metal M3 nuts and bolts. The only tricky part was 
reaching in to place the tiny nuts on the side bolts 
(tip: put a bit of Blu Tack on your finger). For the 
top section, the supplied artwork (or your own) is 
sandwiched between the black panel and a clear 
Perspex one. A microswitched joystick (with ball 
top) and push-fit arcade buttons are then inserted 
- or you could customise it with your own, such as 
Pimoroni’s Plasma buttons (see boxout). 


PLASMA BUTTONS 


To add some extra razzle-dazzle to your Picade 
Console (or Picade), you could swap out the 
standard arcade buttons for Pimoroni's illuminated 
Plasma buttons (£35 / $37). Each clear button 
features a mini PCB with four tiny RGB LEDs on it. 
Daisy-chained together, the PCBs are connected 
to the Picade X HAT's Hacker header for power and 
control - you can program dynamic lighting effects 
and patterns. 
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Once the mini speaker is fitted, you can mount 
a Raspberry Pi on the base and add the key part of 
the system: the new Picade X HAT. Also available 
separately (£15 / $16) for those who want to build 
their own custom arcade machine, the HAT has 
easy-to-use DuPont connectors for the numerous 
joystick and button wires. The only slight issue 
with the Picade Console - which is more compact 
than its original incarnation - is that there's nota 
lot of room inside for all the wiring. 

The Picade X HAT also features a built-in PS DAC 
and amplifier for the internal speaker, and power 
management that allows you to safely shut down 
the Raspberry Pi with the illuminated power button 
on the side of the cabinet. 


Simple setup 
With everything assembled, you just need to plug in 
a keyboard for the simple software setup: installing 
the Picade X HAT driver with a one-line Terminal 
command. With RetroPie running, it's a case of 
setting up the joystick directions and buttons to 
your liking and - once you've added some ROM files 
- you're ready to play your favourite retro games. 
As with the full-size Picade, the unit feels robust, 
with rubber feet to keep it secure on a desk or table. 
The arcade controls are solid, although the buttons 
are leaf-spring rather than microswitched. One 
slight drawback of the Picade Console's smaller 
form factor is that the side utility buttons are 
nearer the front and on occasion we knocked them 
accidentally while playing. Other than that, it's 
just as impressive as the Picade, but considerably 
less expensive. M 


A Allthe parts of the kit 


- assembly is fairly 
straightforward 


Verdict 


With a robust case 
and controls, and 
smart Picade X 
HAT board, it 
provides an 
arcade-style 
experience 

on your TV 

screen at a very 
attractive price. 


9, 10 
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10 Best: | ) (3s 


Improve the sound quality of your 
Raspberry Pi with these digital-to- 
analogue converters 


HiFiBerry Amp- 


Going beyond a DAC is this amplifier 
that you can use as part of a serious 
stereo system. It's Class D and all 
you need to do is connect your 
loudspeakers. It's great for multi- 
room setups. 


> £45/ $57 
> magpi.cc/KWNSpN 


et's not put the Raspberry Pi down here - it’s 

not like its audio output sounds like a worn- 

out video tape in 1992. You can get some good 
sounds from it as standard - however, it can still 
be made much better. This is where a whole host 
of amazing DAC accessories come in. M 


Nanosound DAC  HiFiBerry DAC+ 


This powerful DAC comes in a variety The HiFiBerry DACs are pretty 


of versions for different audio tastes, popular, and come in a range of 
and also includes physical buttons, Sizes and different SKUs for any 
à remote, and you can even get a budget, audio requirements, or 
special case for it. A couple of models Raspberry Pi type. There's also 
even come with a little screen to see a digital/SPDIF version. 


what you're listening to! 


> From £20 / $26 


» From £38 / $48 > magpi.cc/aimAyy 
> magpi.cc/XdxPxP 


Nanosound 
Player 


This all-in-one kit uses the 
Nanosound AMP to create a 
complete stereo system to which 
you just need to connect some 
speakers. It also comes with 

the remote control of the other 
DACs and AMPs, and it's all in one 
neat case. 


> £132/S169 
> magpi.cc/tCRnde 


NNNOSOUND 


All-in-One Hi-Fi DAC Board for Raspberry Pi 
(Basic / Standard / Pro) 


Pi-DigiAMP+ 


IGAudlO is one of the original brands 
producing audio add-ons for the 
Raspberry Pi, and its DigiAMP range 
has recently been updated while 
still being an excellent product. 


> £54/ $69 
> magpi.cc/fisaLH 
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Pi-DACZero 


This Zero-sized DAC is the sibling to 


the full-sized audio DACs for other 
Pi models. Considering the standard 
Pi Zero doesn't have an audio out 
port, you'll need something like this 
for almost any solution where you 
want the Pi Zero to play sound. 


> £17/821 
> magpi.cc/sxVfhU 


Speaker pHAT 


This DAC goes beyond being able to 
output music to a stereo - it makes 
the Pi Zero a stereo thanks to its 
tiny built-in speaker. It even has a 
volume graph to show you just how 
loud your sick tunes are. 


> £12/$13 


pHAT DAC 


Amp Zero pHAT 


This nice and inexpensive DAC 
adds a 3.5 mm audio out port - i.e. 

a headphone jack - to a Pi Zero. 
Which is neat, as it doesn't normally 
have one. You can also solder RCA 
ports on to expand it. 


> £12/$13 
> magpi.cc/SUsJrP 


Digi HAT 


An amp for a Pi Zero? Absolutely, 
and this is one of the few we've 
found. JustBoom produces a great 
range of amps and DACs and this is 
no exception - it's just a lot smaller. 


> £24/$37 
> magpi.cc/2iNJMKP 
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99900902790 
9902023092990 


With optical and coaxial out, you'll 
be able to get some super high- 
quality music with the Digi HAT. 
JustBoom also sells traditional DAC 
versions with standard RCA sockets, 


if you prefer that. 


> £30 / £39 
> magpi.cc/2IMEYFx 


E350325 


With the latest version of 


DA102JC 


= 2 
[: D1620 


COAX OUT 


Raspbian, VLC is now the default 
media player on the Raspberry Pi. 
It handles many kinds of codecs 
and is highly configurable, making 
it the perfect software for your 
DAC-powered Pi. 
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Learn basic electronics 


with Raspberry P1 


Gareth Halfacree takes a look at the best resources 
for those looking to break in to the world of electronics 


| Simple Electronics with GPIO Zero 


Written by The MagPi' s 
contributing editor Phil 


Phil King 


Price: 


including programmable 


lighting, a quick-fire reaction 


to have around even when you've 
worked through all the projects. 


£4/ $5 (free download) contributors Mike 


Hayler, and Ben N 
Electronics with GPI 


magpi.cc/ gpio-zero 


King, with assistance from 


Cook, Richard 
uttall, Simple 
O Zero is 


a one-stop guide to getting 
started with Raspberry Pi- 
controlled electronics. 


Inside, you'll be 


taken on a 


journey from learning about 
individual components and 


reading circuit dia 
building real-wor 


grams to 
d projects 


game, an intruder alarm, and 
even a working robot. 

All the projects are built 
around GPIO Zero, an easy-to- 
use Python library for controlling 
the Raspberry Pi's general- 
purpose input/output (GPIO) 
header. A reference guide at 
the back walks through all the 
functions one-by-one, from 
controlling LEDs to spinning 
motors, making it a handy thing 


All the projects in the book 
are illustrated with easy- 
to-read diagrams and full- 
colour photographs, making 
it simple to match your build 
to the instructions. 

Like all The MagPi Essentials 
books, Simple Electronics with 
GPIO Zero is available to buy in 
print and digitally, or as a free 
download under the Creative 
Commons licence. El 


Concepts Videos 


Get a handle on what 
electricity actually is 


XX Agilent. TN 


PRACTICAL NINJAS’ BASICS OF 
ELECTRICITY AND ELECTRONICS 

If you want to take a step back from 
practical projects and understand exactly 
what electricity is and how it works, these 
short videos are a great starting point. 
magpi.cc/LeyJpu 


BEN EATER'S DIGITAL 
ELECTRONICS TUTORIAL 

This ten-part video series dives into the 
inner workings of components including 
LEDs and transistors, using hands-on 
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investigation to explain the mechanics of 
what's happening in the simplest of circuits. 
magpi.cc/kqiMNF 


ALL ABOUT CIRCUITS’ 

VIDEO LECTURES 

Aimed at a college-level audience, Tim 
Fiegenbaum's lecture series covers a 
wealth of topics, from basic electronic 
concepts all the way through to complex 
devices like microprocessors and 
modern computers. 

magpi.cc/DqrnAT 


+90 


i CamJam Edukits” 


Cambridge Created by volunteer organisers 
Raspberry Jam — of the Cambridge Raspberry Jam 

in collaboration with The Pi Hut, 
Price: 


the CamJam EduKits combine 
all the components you need 
with easy-to-follow worksheets 
suitable for home or classroom 
use - meaning you don’t need 
to worry about buying the right 
components separately. 

There are three kits 
available: the Starter kit, which 
includes the components and 
instructions needed to build 
simple projects with buttons, 


£4 / $5 (free download) 
magpi.cc/pEKWSQ 


- ix Enk 
> Zum 
i: Sing 


LEDs, and a buzzer; Sensors 
kit, which adds temperature, 
motion, and light sensing 
components; and the largest, 
Robotics kit, which has the 
components needed to build 
a wheeled robot. 

The kits are designed for use 
with Python via GPIO Zero, 
though community-provided 
Scratch programs are also 
available for most projects. 
All worksheets are free to 
download under a Creative 
Commons licence. M 


Workshop 
for Beginners 


If you’re new to Raspberry 

Pi itself, rather than just 

Price: electronics, Core Electronics’ 
Free beginners’ workshop course is 
magpi.cc/ YCOsZj 


Core Electronics 


Raspberry Pi 


a great introduction. Through 

a series of hands-on videos, 
coupled with a webpage for 
circuit diagrams and code 
extracts, you'll learn everything 
from how to load an operating 


system onto your Pi to using 
its GPIO header to drive a 
simple circuit. 

Core Electronics! course 
goes a little further than most: 
once you're comfortable with 
the basics, you can continue 
watching the video series to 
learn more advanced topics 
like shell scripting, writing 
graphical user interface (GUI) 
programs, and even connecting 
your Pi up to the Internet of 
Things (IoT). 

All the videos are filmed 
in high quality and are free 
to watch via the company's 
YouTube channel. El 
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Get everything you 
need in once place 


MODMYPI YOUTUBE 
WORKSHOP KIT 
Designed for use alongside 
an accompanying nine-part 
video series with freely 
downloadable worksheets, 
ModMyPi's bring-your-own- 
Pi kit covers a range of basic 
projects in Python using the 
RPi.GPIO library. 

> magpi.cc/apwuju 

> £16/$20 


MONK MAKES 
STARTER KIT 

Put together by noted 
technology author Simon 
Monk, the Monk Makes 
Starter Kit comes with a basic 
selection of components, 
plus printed instruction 
cards with diagrams for ten 
interesting projects. 

> magpi.cc/fiuyya 

> £13/$16 


VELLEMAN RASPBERRY PI 
BASIC LEARNING KIT 
Designed for the more 
advanced user, Velleman's kit 
comprises 75 pieces including 
a handy GPIO extension board, 
remote control, servo motor, 
flame sensor, and seven- 
segment LED displays. 

> magpi.cc/RqPYWD 

> £63/$65 
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WE Magri | INTERVIEW 


Alex 


Martinez 


A desire to compete in robotics brought workshops 


in Raspberry Pi to a Puerto Rican school 


> Category Educator 


and soils,” Alex 


mentions to us. He’s recently 
tagged The MagPi Twitter 
account into a post about his 
workshops in Puerto Rico. “I 
graduated from the Department 
of Geology of the University of 
Puerto Rico. I took a C++ course 
which I found very interesting 
and that was it, until the 

maker movement hit me five 
years ago.” 


y background is 
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really related to rock 


Alex helped start a makerspace 
with his friends and family 
in 2014, and he learnt all 
about microcontrollers and 
the Raspberry Pi from the 
community that gathered there. 

“Then, back in 2016 I went to 
US to be part of the first cohort of 
Raspberry Pi Certified Educators,” 
Alex reveals. “Since then I have 
been introducing the Raspberry Pi 
ecosystem to the classroom and 
helping fellow educators in the 
island with talks and workshops 
along with fellow makers.” 
Like us, you may be wondering 
how the US territory of Puerto 
Rico is doing after Hurricane 
Maria devastated it last year. Alex 
himself refers to Puerto Rico today 


Did you know the box 
also doubled as a 
robot chassis? 


Workshops use the 
CamJam Edukit 3 


> Day job Teacher | » Website magpi.cc/SBynYZ 


as paradise, but it’s clear there are 
still some long-lasting effects: 
“The hurricane hit us very 
bad. We had to cancel many 
maker-related events and 
gatherings. Many of our friends 
still work on their personal 
projects on their houses, but we 
lost most of the momentum by 
staying closer to family.” 


What prompted you to start 
the workshops? 

The current workshop that we 
are giving in my school started 
because my school Director 
wanted me to enter a robotic 
league competition, but the 
fees and equipment were very 
expensive and we couldn’t 


yy = 


afford it. Most of the educators 

I talked to are experienced in 
VEX [robotics] competitions and 
had been in the US finals, but 
never had an experience on any 
Raspberry Pi-related projects. 
This was another reason to start 
these workshops: many of them 
wanted to build projects from 


Many of them wanted to build 
projects from scratch and teach their 
kids computer programming skills 


scratch and teach their kids 
computer programming skills. 
The Raspberry Pi community 

is very resourceful and here 

we found the Pi Wars events. 

So I sent a message to Pi Wars 
organisers in order to ask 

for permission to make a Pi 
Wars-like event with fellow 
educators here in Puerto Rico. 

I asked my colleague Damaso 
Cardenales - who is a member of 
our Makerspace PR, Inc., and a 
computer programmer - to help 
me with this project. 


What kind of things do you 
teach in the workshops? 

For these workshops we are 
using the CamJam Robotics kits 
that you can find in The Pi Hut. 


MéigPi 


Students learn 
about code 


People from 
around the 
island attend 
the workshops 


Making robots 


The majority of the teachers is fun, but 
sometimes 
and students are new to the hard work 
platform, so the workshops are BINUSTS 
divided on the level of difficulty. inspired Alex's 


Teaching [ranges] from how to workshops 


burn a Raspbian image on the SD 
card, to working with the GPIOs 
using Python, and remotely 
accessing Raspbian from another 


computer. We have been giving 
three workshops until now and 
are planning more in the future. 


How well have the workshops 
been received? 
In my opinion, the workshops 
were so good that we had home- 
schoolers coming in, and parents 
with kids attending the sessions. 
There is a great effort from other 
schools to bring these workshops 
closer to them. Also, we are 
planning to hold a Pi Wars event 
next year. 

For next year, I am planning 
- with the awesome people of 


Helping out the Puerto Rican 
maker community 


If you're interested in getting involved with the 
Puerto Rican maker community, Alex is happy 
to talk to you. You can contact him at: 


MakertechPR, a local DIY and Twitter 
electronics store - a Raspberry Facebook 
Pi summer workshop for the Email 


University of Puerto Rico. 
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Season's greetings from Raspberry Pi Land! 


Ithough this is our January issue, you 

very likely might be reading this right 

before Christmas. So to fleetingly keep 
in theme with the season, here are some of 
the great Christmas Pi projects we've seen 
this month! 


What do you do 
when you don't have 
a Christmas wreath? 
Well, apparently one 
office decided to 
make one out of RAM 
sticks and put some 
LED lights behind 


it, powered by a 


Raspberry Pi. As you 
do. We really like the 
Ethernet cable tied 

in a bow on top of it. 
Really sells the piece. 
magpi.cc/jjdWiz 
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It's hard to remember 
a time before ‘ugly’ 
Christmas jumpers 
came back into fashion 
- although we'd argue 
many of them are 

no longer very ugly. 
Anyway, while we've 
seen light-up ones 

in the past, we've 

not seen any that are 
synchronised to music 
to create a lovely 
display. Check out the 
link to see a video of it 


in action. 
magpi.cc/BdepuS 


Christmas 2018 


Mádpi 
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ME Mägi | THIS MONTH IN RASPBERRY PI 


New UK Scou 
resources! 


The Digital Maker badge gets upgraded 


ix months ago, the Raspberry Pi 
S Foundation announced a partnership with 
the Scout Association in the UK, launching 
the Digital Maker Staged Activity Badge. As you 
can see from the number on the badge, they’re 
‘staged’ to several levels. Resources were released 
for stages 1 and 2 and now the Foundation 
is releasing more, as Olympia Brown, Senior 
Programme Manager explains in her blog post: 
“Since then, we’ve been developing resources 
for more stages of the badge, and we’ve just 
released activities to support more of stage 2 
and stage 3. 


ti The first set of activity resources 
we released either needed no 
technology or laptops only @ 


“Because the Digital Maker badge is a staged 
activity badge, any section of the Scouts 
movement can tackle it. And since an activity 
that interests and engages a Beaver is likely to be 
quite different to one that engages an Explorer 
Scout, we've increased the variety of activities 
we're providing. 


More tech! 

“The first set of activity resources we released 
either needed no technology or laptops only, as 
the leaders we spoke to told us it shouldn't be too 
difficult to get hold of some laptops for a session. 
For the new resources, we've increased the variety 
of tech that we recommend using. Some of the 
activities use the micro:bit, since it's a low-cost, 
easy-to-use bit of tech. For leaders unfamiliar 
with the micro:bit, we've put together this guide 
on using the device: magpi.cc/nyRgJj. 
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S Find the Scouts 
resources here! 
magpi.cc/nwriRe 


© Tocaue C Follow ) v 


We've teamed up with our friends at 
@Raspberry_Pi to give you even more 
resources to get stuck into! Here's, Scout 
Ambassador, (Gastro timpeake telling you 
why it's so important that young people 
improve their digital technology skills. 


Read more here: bit.ly/2egjSLV 


Hello, l'm«Lim Peake and a 


v proud Scout Ambassado 


A Tim Peake, the first Astro Pi astronaut, 
has helped promote the new badge! 


More activities! 

“With all our activity resources, we show how 
digital making fits into the scouting movement 
and into many typical activities you'd do with your 
troop. For example, you can program the micro:bit 
to be the musical accompaniment to your next 
campfire (magpi.cc/AdiJyc). Or, you can create 
your own custom map to show points on a recent 
hike that you did together (magpi.cc/GEzWYa) - 
anything from where someone fell over, to where 
you saw the most amazing view.” El 


o] 


BUILD UP 
IN MINUTES 
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TinyPi Pro Arcard 


We covered the original version of this project in The Tabletop arcade machines are great, but some of them 
MagPi a while ago, and the creator has finally deemed it can be a bit expensive, The Arcard brings down the price 
worthy to be made into a product. He needs your help, slightly by having a case made entirely of cardboard. It's 
though, to raise enough cash to start production, and of also big enough for two sets of controls, which not every 
course you can net yourself a kit for your pledge. Pi-powered arcade can do 

kck.st/2PdLFNV kck.st/2Ubmq2r 


Best of the rest! Here are some other great things we saw this month 


STEAM LINK ON RASPBERRY PI! | CUSTOM VINTAGE PI COMPUTER 


FRASIER SHUFFLER 


So this is pretty amazing news - although Taking an old Beckman terminal, Imgur 
Valve has discontinued its Steam Link user 'iafan' has converted it to use a 
hardware, it's just released an app for Pi. The old CRT was replaced with an 
Raspbian that does the same thing. We'll LCD screen, and the remaining space 
have more thorough coverage of it next was used to house the Pi and other 
issue, but for now... wow. components. It Looks pretty cool. 


4) STEAM 
» magpi.cc/pUFkTf > magpi.cc/sLDRcG 


The Simpsons shuffler was great, but we 
also love this Frasier shuffler. The wooden 
case and big arcade button give ita 

nice look, and you could probably make 
the case resemble the cask for a 1982 
Chateau Latour to suit Frasier's tastes. 


=a 
> magpi.cc/HctpPd 
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Raspberry Jam 
Event Calendar 


Find out what community-organised Raspberry Pi-themed 


events are happening near you... 


01. Stafford Raspberry Jam 
5 Tuesday 8 January 
Q Stafford Library, Stafford, UK 


» magpi.cc/PESDWA 
A big meet-up for people of all ages to get together 
share their Pi ideas while having fun. 


02. DC Raspberry Jam 

^ Saturday 12 January 

9 Mount-Pleasant Library, Washington DC, USA 
» magpi.cc/nmxWjr 


An event for kids to get into Pi-based robotics and coding. 


There's also a 3D-printed robot to have fun with. 


03. Raspberry Jam @ Castro Valley Library 
© Saturday 26 January 

Q Castro Valley Library, Castro Valley, CA, USA 

» magpi.cc/xjipLg 

If you're interested in coding and want to know more 
about the Raspberry Pi, check out this Jam. 


04. Saddleback Valley Raspberry Jam 
© Saturday 2 February 
9 Laguna Hills High School, Laguna Hills, CA, USA 


» magpi.cc/kwDpdp 
Projects will be on display from community members, 
and there will also be beginners' workshops. 
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05. Cornwall Tech Jam 


© Saturday 12 January 

Q9 Bodmin Library, Bodmin, UK 

> cornwalltechjam.uk 

Learn about programming on a variety of platforms, 
including Raspberry Pi, in various languages. 


06. Dallas Young Makers Club 

© Saturday 12 January 

Q J.Erik Jonsson Central Library, Dallas, TX, USA 
> dallasyoungmakers.org 

Learn about computing and robotics on 

Raspberry Pi at this free workshop for kids! 


FULL CALENDAR 


07. January Raspberry Pint Get a full list of upcoming 
© Tuesday 29 January 

Q9 CodeNode, London, UK 

» magpi.cc/PXtDiX 

If you're working on a Pi project. or would like 


some help on it, head down to Raspberry Pint! 


events for January and 
beyond here: 


rpf.io/jam 


08. Leeds Raspberry Jam 

^ Wednesday 6 February 

Q9 Dixons Unity Academy, Leeds, UK 

» magpi.cc/cqDJms 

Get hands-on with digital making activities in the 
workshop, and a hackspace area to share projects. 
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$ FIND OUT 
ABOUT JAMS 


Want a Raspberry Jam 


in your area? 
Want to start one? 


Email Ben Nuttall about it: 
V % 8 
jam@raspberrypi.org 
eo 
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> d 
O We've highlighted some of the areas & 


in need of a Jam! Can you help out? 


Raspberry Jam advice: 


Themed activities 


áá W hen a competition like Astro Pi, 
or a programme like Pioneers 
comes out, we’ll do talks and 
invite people along to take part in workshops 
at the Jam. It’s good because it gives an «95 - 
incentive for people to come along and take m ao € A 
part, and gives them motivation to work." 


Andy Melder - Southend Raspberry Jam 


Every Raspberry Jam is entitled to apply for a 
Jam starter kit, which includes magazine issues, 
printed worksheets, stickers, flyers and more. 
Get the book here: magpi.cc/2q9DHfQ 
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Your 


Letters 


O 


» 
STEAM 


A With the old Steam 
Link hardware being 
discontinued, we were 
wondering what Valve 
might do! 


I'm really excited about Steam 
coming to the Raspberry Pi! 
How long has this been in the 
works? Will it be able to play 

all of the games in the Steam 
library? Do I need the latest 
Raspberry Pi for it? I have many 
questions! Can't wait for a 
special Steam Pi to replace the 
current Steam Link hardware! 


Tyler via Facebook 


It's not actually a full Steam 
client on the Raspberry Pi - 
it's Steam Link, the streaming 
service. You'll need a computer 
already running Steam on your 
network to get it working, 
but you do get access to all 
the games available on your 
gaming PC! It was news to 
us as well, though - Valve is 
quite secretive. 

You will need a Raspberry Pi 3 
(Model B): either an original 
Pi 3 or a 3B+. We've not tested 
it on a 3A+, but we can only 
imagine that reduced RAM 
isn’t ideal for it. Otherwise, 
just make sure you have as 
much of the network wired up 
as possible, and then just plug 
in a compatible controller! 
Check out the details here: 
magpi.cc/pUFkTf. M 
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A These smart lights helped 
inspire 'oldjake' - did they 
inspire you? 


Let there be light 


If there was nothing else 
interesting in any other edition 
of The MagPi, I would still pay for 
them all just for the article about 
IKEA lights from last issue! 

I’ve got loads of their bulbs 
around the house as I’m 
swapping all my lights from 
Hive to Tradfri. One of the 
things missing from the Tradfri 
platform is the ability to turn a 
light on at sunset — you can only 
set an absolute time. 

So, this morning, I thought 
I'd have a play (I’m very new to 
Python so this isn't intuitive). 
Couple of hours later and I've 
got a little Python script that 
gets the sunset time, compares 
it with the current time, and 
switches the lights on if it’s 
later than sunset. I’m running 
some other home automation 
stuff with a script that runs 
every few minutes, so it'll be 
dead easy to add this in. 

For the record, as it’s in 
the spirit of ‘hacking’ home 
automation, my pet project, 
which is what got me started in 
this, is occupancy detection so 
that I can control the heating 
depending on who’s in. I’ve 
now got that 99% working. 
There’s a Pi in the lounge 
that sniffs for the Bluetooth 


MAC addresses of the phones 
in the house. If it finds one, 

it increments a score. If the 
score is zero then it turns the 
heating down. I’ve even got 

it weighted so that if I’m in 
the house, it turns the heating 
up a bit more. I’m using the 
very badly documented Hive 
API to do this, so it’s been a 
bit of a labour of love. When 

I started this, I knew nothing 
about Python or APIs, or much 
else that would help with this. 
I don’t do ‘Hello World!’ so this 
has definitely been a bit of a 
baptism of fire for me. 

I've done a bit of a write-up 
here: magpi.cc/iHSdpB. 


oldjake from the forum 


Wow! We're extremely impressed 
with the work you've done here. 
We don't want to toot our own 
horns too much but when we see 
readers taking a tutorial we've 
done and using it in a current 
project, it makes it all seem 
worth it! 

For folks who are interested 

in how oldjake has fared 

so far, you can read more 

in the forum thread about 

his accomplishments here: 
magpi.cc/uCrx]W. El 
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The MagPiTV 


After reading the article 
entitled ‘BBC Computer 
Literacy Archive’ [from issue 
73], it made me think... 

What about a Raspberry 
Pi BBC programme? After 
watching the BBC Micro 
programme many years ago, 
eagerly awaiting each episode, 
I went on to eventually work in 
IT and now at 60 I have still not 
lost the enthusiasm I have for 
computers thanks to the BBC. 

This made me wonder why 
the BBC has not produced a 
similar programme, brought 


A Check out our YouTube 
for great videos, like this 
tour of Raspberry Fields! 


up to date of course, using a 
Raspberry Pi instead of the 
BBC Micro, with maybe a 
new hardware project each 
week including how to create 
a program in Python to 
control it? 

Ithink any children with an 
interest in computers and the 
Raspberry Pi (which is in most 
schools) would love it, with the 
added bonus of again helping 
children in school with maths 
and logic problem solving. The 
low price of the Raspberry Pi 
makes it an ideal platform. 


The Government seems 
supportive. An easy cheap 
programme to make? 
What do you think? 


Mike via email 


If you've ever met our Features 
Ed Rob, or seen any of the 
videos on our YouTube channel 
(or even been to certain UK 
comic cons), you'll know he 
loves being in front of the 
camera. Unfortunately, it's up 
to the BBC to fund and develop 
that kind of programming. 
Speaking of our YouTube 
channel, if you want to see 
Raspberry Pi content on a 
semi-regular basis, make 
sure to subscribe. We do 
unboxings, tutorials, walking 
tours, and more. Check it out 
at magpi.cc/youtube. M 


Contact us! 


@TheMagPi 

> Facebook magpi.cc/facebook 

> Email magpi@raspberrypi.org 
> Online raspberrypi.org/forums 


> Twitter 


Coolest Projects is a world-leading annual showcase that 
empowers the next generation of digital innovators: young 
people from across the whole Raspberry Pi community come 
together to exhibit their awesome projects. 

Join Coolest Projects at The Sharp Project, Manchester on 
Saturday 2 March, and see them share their ideas and their 
passion for technology, make new friends, and learn from one 
another. Bring family and friends, see crazy science shows by 
TV presenters, and have a go yourself at the exciting activities. 

Why not get involved yourself? You don't need to know how 
to code. They need volunteers with enthusiasm and a variety 
of skills for Coolest Projects. If you do know how to code, that's 
great, but you don't need any technical skills to help make this 
day an amazing event for young people. 


coolestprojects.org 
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Simple coding for total beginners 


The first 
Code Club book 
has arrived! 


Learn to code 
using Scratch, the 
block-based language 


Hd qnd 9mpo-» 
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Follow step-by-step 
guides to create games 
and animations 


Use the magic glasses 
to reveal secret hints 


Includes 24 exclusive 
Code Club stickers! 


The special spiral 
binding allows 
the book to lay flat 


Raspberry Pi 
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One of Ten 
Cluster HATs 


and create a P1 powerhouse! 


m The Cluster HAT is a simple 
and compact way to build 
a low-cost USB-connected 
Raspberry Pi Bramble E 


Take a Raspberry Pi 3B+, add a Cluster HAT, and fill it with 8086 Consultancy has given us ten Cluster HATs to 


up to four Pi Zero boards and you've created a parallel- give away, so enter today for your chance to win one 
processing beast that lets you do some really fun stuff. (Pi 3B* and Pi Zero boards not included). 
Head here to enter: magpi.cc/win | Learn more: clusterhat.com 


Terms & Conditions 


Competition opens on 19 December 2018 and closes on 31 January 2019. Prize is offered to participants worldwide aged 13 or over, except employees of the Raspberry Pi Foundation, 
the prize supplier, their families or friends. Winners will be notified by email no more than 30 days after the competition closes. By entering the competition, the winner consents to any 
publicity generated from the competition, in print and online. Participants agree to receive occasional newsletters from The MagPi magazine. We don't like spam: participants’ details 
will remain strictly confidential and won't be shared with third parties. Prizes are non-negotiable and no cash alternative will be offered. Winners will be contacted by email to arrange 


delivery. Any winners who have not responded 60 days after the initial email is sent will have their prize revoked. This promotion is in no way sponsored, endorsed or administered by, 
or associated with, Instagram or Facebook. 
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ISSUE #14 


OUT NOW 


4 Available on the GETIT ON 
€ App Store P» Google Play 


Next Month 


BUILDA 


PINBALL 
MACHINE 


Make your own 
ball flipper with 
Raspberry Pi 
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THE MAGPI ON SALE 


The C64 made from Lego 

magpi.cc/subscribe 
Create your own GTheMagPi 
Sense HAT MP3 player 


fb.com/MagPiMagazine 
magpi@raspberrypi.org 
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ME Magi | THE FINAL WORD 


Remember. 


Create. 


K.G. Orphanides on silence, preservation, and the joy of trashgames 


Pi Model B, but it took a while 
for me to click with it. As Pi 
iterations became more powerful, 
their capabilities intersected with 

the needs of my other projects. 

A Piis at the heart of my silent 
recording studio for voiceover work 
and field recording. The biggest 
problem with home audio recording 
from a mic input is the inevitable 
background noise from the fans 
of a standard desktop or laptop PC. 

Equipped with passive heatsinks, 
there's nothing in my Pi 3 box to make 
the slightest noise, so I can record 
almost anywhere without unwanted 
background noise to cancel out - at 
the cost of other sounds in the same 
frequency range - during production. 

The next upgrade is a fully portable 
and ideally weatherproof version 
for field recording in nature. That's 
going to call for a touchscreen, 

a hefty battery, and an IP6X 
weatherproof chassis. 


| reviewed the first Raspberry 


Preserving the past 

A Pi 3 is also key to my interest in 
software preservation and emulation. 
I have a lot of classic computers and 
consoles, but it’s usually my Pi-based 
emulation box that I get out when I 
want to show someone what gaming 
felt like in the 1980s and 1990s. It 

fits in a pocket and doesn’t run the 
risk of a capacitor going fizz at a 
crucial moment. 
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But it’s about more than playing 
well-loved games that are otherwise 
unlikely to see a re-release. There are 
whole classes of games and software 
that are at imminent risk of being lost 
to history, and the Pi provides a useful 
test bed for getting a lot of those 
running, assessed, and documented. 


numerous unfinished projects and 
false starts, I didn’t release my first 
game - the text adventure ‘Eight 
characters, a number, and a happy 
ending’ - until my mid-30s. 

While I don't exclusively develop 
on a Pi, it's what got me back into 
programming. It reminded me that 


m Write software for the pleasure of puzzling 
out the logic and structure needed to create a 
meaningful experience in a few lines of code El 


While there's no chance that we'll 
lose Doom, Ultima IV, or Lemmings, 
preservation is less certain for 
novelty screensavers, cheap 
CD-ROM compilations of fascinating 
Windows 95 ‘shovelware’, 3.5-inch 
floppies packed with cheat tools and 
‘trainers’ to boost your RPG party's 
stats, or Java phone games. 

Pm using a Pi to find working 
versions of games like Rovio's 
Darkest Fear survival-horror/puzzle 
series - released long before Angry 
Birds was a hit - and the elusive 
feature-phone version of Fallout 1, 
with the intention of curating an 
online archive. 


Coding the future 

But I most love the Pi for the 
opportunities it holds for new 
developers of all ages. Despite 


I could write software for the joy of it; 
for the pleasure of puzzling out the 
logic and structure needed to create a 
meaningful experience in a few lines 
of code. 

Like home microcomputers of the 
1980s, the Pi can turn anyone into 
a bedroom programmer, ready to 
join the thrilling indie, art games, 
and wonderfully glitchy trashgames 
scenes born of widespread internet 
access and high-quality, free 
development tools like Twine 
and PICO-8. Hl 


K.G. Orphanides 


K.G. is a writer, developer, and 
Software preservation enthusiast 
with a penchant for narrative games, 
nineties CRPGs, and owlbears. 


@KGOrphanides 


THE Official 
RASPBERRY PI 
EGINNERS BOOK 


THE EASY WAY! 


Pi Zero W computer 


Official case with three covers 
USB and HDMI adapters 

8GB microSD card 

116-page beginner’s book 
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RASPBERRY PI 


The pocket-sized desktop computer! __—— 
PI ZERO 


magpi.cc/store 


Cana 


TL 


e Co pne: 


A Wiley Brand 


Build your own credit card 
sized computer 


Get started with programming 
Setup a Media Center 


Make simple electronic circuits 
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Available in Europe 
Available for worldwide shipping at: through RS Components 


$89? £69? 


US DOLLARS EXCLUDING VAT 


Raspberry Pi is a registered trademark of the Raspberry Pi Foundation. 
For Dummies and the Dummies Man logo are trademarks or registered 
trademarks of John Wiley & Sons, Inc. Used under license. RS logo is 

a registered trademark of RS Components Ltd. Canakit is a registered 
trademark of Cana Kit Corporation. 
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